react native 字體隨系統(tǒng)字體變化而變

react native 字體不隨系統(tǒng)字體變化而變---liu_520
rn寫的軟件內(nèi)的字體(text組件)會(huì)隨著手機(jī)系統(tǒng)字體大小的變化而變沪伙。
1声畏、android 的解決方案是:

const fontSizeScaler = PixelRatio.get()/PixelRatio.getFontScale()

fontSize:18*fontSizeScaler

其中用到了PixelRatio的兩個(gè)方法浊服,
get() 返回設(shè)備的像素密度,
getFontScale()返回字體大小縮放比例. 這個(gè)比例可以用于計(jì)算絕對(duì)的字體大小, 所以很多深度依賴字體大小的組件需要用此函數(shù)的結(jié)果進(jìn)行計(jì)算.
如果沒有設(shè)置字體大小, 它會(huì)直接返回設(shè)備的像素密度.
目前這個(gè)函數(shù)僅僅在Android設(shè)備上實(shí)現(xiàn)了, 它會(huì)體現(xiàn)用戶選項(xiàng)里的 "設(shè)置 > 顯示 > 字體大小". 在iOS設(shè)備上它會(huì)直接返回默認(rèn)的像素密度.
感興趣的同學(xué)可以打印測(cè)試下:

字體隨著系統(tǒng)字體變化

由此我們可以看出存璃,系統(tǒng)的字體越大叉存,PixelRatio.getFontScale()字體的縮放比越大,反之越小昙衅,fontSizeScaler的值就越小和系統(tǒng)字體成反比扬霜,才能在系統(tǒng)字體變大的情況下,軟件的字體相對(duì)變小而涉,總體大小保持不變
2著瓶、ios 的解決方案是:
ios 上返回的默認(rèn)就是像素密度,所以不起作用啼县,需要用到text的一個(gè)屬性材原,這個(gè)屬性只對(duì)ios生效:

allowFontScaling={false}

這樣的話,軟件中的字體就不會(huì)隨著系統(tǒng)字體的變化而變了季眷,但是不管在大屏7plus還是小屏5s余蟹,字體的大小都是一樣的,這樣在小屏幕手機(jī)上布局又會(huì)變化瘟裸。
這樣的話我們要針對(duì)小屏幕的手機(jī)再次優(yōu)化客叉,判斷像素比诵竭。

if (pixelRatio === 2) {
    // iphone 5s and older Androids
    if (deviceWidth < 360) {
        return size * 0.95;
    }
    // iphone 5
    if (deviceHeight < 667) {
        return size;
    // iphone 6-6s
    } else if (deviceHeight >= 667 && deviceHeight <= 735) {
        return size * 1.15;
    }
    // older phablets
    return size * 1.25;
 }
if (pixelRatio === 3) {
    // catch larger devices
    // ie iphone 6s plus / 7 plus / mi note 等等
    return size * 1.27;
}

里面的比值大家根據(jù)自己的實(shí)際情況自行調(diào)整话告,

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市卵慰,隨后出現(xiàn)的幾起案子沙郭,更是在濱河造成了極大的恐慌,老刑警劉巖裳朋,帶你破解...
    沈念sama閱讀 222,865評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件病线,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡鲤嫡,警方通過查閱死者的電腦和手機(jī)送挑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,296評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來暖眼,“玉大人惕耕,你說我怎么就攤上這事〗氤Γ” “怎么了司澎?”我有些...
    開封第一講書人閱讀 169,631評(píng)論 0 364
  • 文/不壞的土叔 我叫張陵欺缘,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我挤安,道長(zhǎng)谚殊,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,199評(píng)論 1 300
  • 正文 為了忘掉前任蛤铜,我火速辦了婚禮嫩絮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘昂羡。我一直安慰自己絮记,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,196評(píng)論 6 398
  • 文/花漫 我一把揭開白布虐先。 她就那樣靜靜地躺著怨愤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蛹批。 梳的紋絲不亂的頭發(fā)上撰洗,一...
    開封第一講書人閱讀 52,793評(píng)論 1 314
  • 那天,我揣著相機(jī)與錄音腐芍,去河邊找鬼差导。 笑死,一個(gè)胖子當(dāng)著我的面吹牛猪勇,可吹牛的內(nèi)容都是我干的设褐。 我是一名探鬼主播,決...
    沈念sama閱讀 41,221評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼泣刹,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼助析!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起椅您,我...
    開封第一講書人閱讀 40,174評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤外冀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后掀泳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體雪隧,經(jīng)...
    沈念sama閱讀 46,699評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,770評(píng)論 3 343
  • 正文 我和宋清朗相戀三年员舵,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了脑沿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,918評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡马僻,死狀恐怖庄拇,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巫玻,我是刑警寧澤丛忆,帶...
    沈念sama閱讀 36,573評(píng)論 5 351
  • 正文 年R本政府宣布祠汇,位于F島的核電站,受9級(jí)特大地震影響熄诡,放射性物質(zhì)發(fā)生泄漏可很。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,255評(píng)論 3 336
  • 文/蒙蒙 一凰浮、第九天 我趴在偏房一處隱蔽的房頂上張望我抠。 院中可真熱鬧,春花似錦袜茧、人聲如沸菜拓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,749評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)纳鼎。三九已至,卻和暖如春裳凸,著一層夾襖步出監(jiān)牢的瞬間贱鄙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,862評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工姨谷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逗宁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,364評(píng)論 3 379
  • 正文 我出身青樓梦湘,卻偏偏與公主長(zhǎng)得像瞎颗,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子捌议,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,926評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容