React native 字体大小适配

本文介绍了如何在React Native中进行字体大小适配,包括基于屏幕宽度的比例适配以及防止字体大小随系统字体大小变化的方法,如设置allowFontScaling属性为false,并提供不同版本React Native的实现细节。
摘要由CSDN通过智能技术生成

1、根据屏幕宽度比例适配

定义ratio_w = Dimensions.get('window').width / 375(按着750x1334出设计稿)

所有字体大小定义 * ratio_w进行适配。

2、字体大小不随着系统字体大小变化

2.1 设置Text/TextInput组件的 allowFontScaling = false 属性

2.2 封装自定义CustomText/CustomTextInput组件,render 返回Text/TextInput组件,属性添加 allowFontScaling=false,所有使用到相关组件时,直接引用CustomText/CustomTextInput来代替

2.3 Text的render方法,不适用TextInput组件

react native 0.56之前版本,这样实现

Text.prototype.render = _.wrap(Text.prototype.render, function (func, ...args) {
    let origin = func.apply(this, args)
    return React.cloneElement(origin, {allowFontScaling: false})
})

react native 0.56版本及以后版本,如此实现

Text.render = _.wrap(Text.render, function (func, ...args) {
    let origin = func.apply(this, args)
    return React.cloneElement(origin, {allowFontScaling: false})
})

2.4 通过defaultProps来设置

TextInput.defaultProps = Object.assign({}, TextInput.defaultProps, {defaultProps: false})

Text.defaultProps = Object.assign({}, Text.defaultProps, {allowFontScaling: false})

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值