react-native-linear-gradient兼容问题

背景

react-native-linear-gradient

可能因为react-native版本过低问题,导致无法支持react-native-linear-gradient,所以需要进行兼容处理。

requireNativeComponent: “BVLinearGradient” was not found in the UIManager.

代码

Utils.ts:

import { NativeModules } from 'react-native';

export function isNativeComponentExisted(componentName: string): boolean {
  return (
    NativeModules.UIManager &&
    NativeModules.UIManager.hasOwnProperty(componentName) // here
  );
}

MyLibraryGradient.tsx:

import * as React from 'react';
import { View } from 'react-native';
import LibraryGradient, {
  LinearGradientProps,
} from 'react-native-linear-gradient';
import { isNativeComponentExisted } from './Utils';

/**
 * @name LinearGradient
 * @desc Check {@link https://github.com/react-native-community/react-native-linear-gradient#additional-props react-native-linear-gradient} for configuration details
 * @param {Object} LinearGradientProps
 */
const RNLinearGradient = (props: LinearGradientProps) => {
  const useCompat = !isNativeComponentExisted('BVLinearGradient');
  if (useCompat) {
    const { start: _, end: __, colors: ___, locations: ____, ...rest } = props; // 排除start,end等属性,这些属性对于View组件是不对的
    return (
      <View
        {...rest}
        style={[props.style, { backgroundColor: props.colors[1] as string }]}
      />
    );
  }
  return <LibraryGradient {...props} />;
};

export default RNLinearGradient;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值