RTL適配實踐

背景

  • 阿拉伯語適配是一個比較麻煩的事情蟆豫,不僅僅在于它文案的適配,更多的是在于其語言習慣的變化。由從左到右(LeftToRight)的布局習慣變?yōu)榱藦挠蚁蜃?RightToLeft)的布局習慣尊剔。
    https://sabq.org/
    http://wam.ae/ar
  • 通過上面的網(wǎng)站,可以很直觀地看出像阿拉伯語菱皆,典型 RTL 布局網(wǎng)站的特點:
    • 文字都是右對齊须误,并且是從右往左閱讀的
    • 排版都是從右到左的,在一個產(chǎn)品列表中仇轻,右邊第一個商品是第一個
    • 箭頭代表的意義剛好相反京痢,比如在輪播圖中,向左箭頭代表下一幀篷店,而向右箭頭則代表查看上一張圖片

思考

對于rtl網(wǎng)站的適配祭椰,這里有兩種方案參考
1、direction 布局方案
2疲陕、transform鏡像翻轉(zhuǎn)方案

direction 布局方案

  • direction是css屬性畜眨,css手冊中對direction的描述:該屬性指定了塊的基本書寫方向扯躺,以及正對Unicode雙向算法的嵌入和覆蓋方向。
  • 通俗的講就是:
    1、定義過 direction:rtl 的元素晦墙,如果沒有預先定義過 text-align,那么這個元素的 text-align 的值就變成了 right粤剧,如果設(shè)置了 left/center 則無效
    2奕污、對于數(shù)字和標點符號以外的編碼,順序仍然是從左到右的
    3按厘、改變了 inline-block 元素的書寫順序
  • direction適配方案借助rtlcss 模塊來完成医吊。
.test: {
  direction: rtl;
  margin-right: 10px;
  float: left;
}

通過rtlcss模塊處理后

.test: {
  direction: ltr;
  margin-left: 10px;
  float: right;
}

最后通過一套代碼編譯成一套 html,多套 css逮京,一套 js 文件卿堂,區(qū)分國家用戶來進行訪問。

transform鏡像翻轉(zhuǎn)方案

transform鏡像翻轉(zhuǎn)通過一套html懒棉,一套css草描,一套js文件既可完成ltr和rtl適配
  • 對比了一下direction和transform的方案,最終我在項目中選擇了transform方案策严,transform實現(xiàn)起來比較簡單穗慕,但是也存在缺陷,這個下面會提到妻导。
  • transform鏡像翻轉(zhuǎn)實現(xiàn)rlt和ltr原理:
    • transform: scaleX(-1); 以使頁面沿著中軸進行水平翻轉(zhuǎn)逛绵,通過水平翻轉(zhuǎn)怀各,原本 LTR 的布局頁面會變成RTL布局頁面,但圖片和文字會被相對于的翻轉(zhuǎn)了术浪,這時候在被翻轉(zhuǎn)的文字和圖片上設(shè)定transform: scaleX(-1)鏡像翻轉(zhuǎn)回來就完美實現(xiàn)了瓢对,理論看似很簡單,實際上會遇到一些問題;
下面介紹一下我在項目中的實現(xiàn)(react中臺項目)

封裝一個FlipBox組件用來包裹需要翻轉(zhuǎn)的text和img(FlipBox 可以替換頁面中的span標簽胰苏,img通過div包裹)硕蛹,獲取url中的locale字段,locale字段來判定LTR布局還是RTL布局硕并。

const locale = localeDeal() || 'en-US';
export const FlipBox = ({ children, ...props }) => {
  if(typeof children === 'string') {
      return (
        <span
          {...props}
          style={{ transform: (locale === 'he-IL' || locale === 'ar-EG') ? 'scaleX(-1)' : 'none' }}
        >{ children }</span>
      )
  }
  return (
    <div
      {...props}
      style={{
      display: 'inline-block',
      transform: (locale === 'he-IL' || locale === 'ar-EG') ? 'scaleX(-1)' : 'none',
    }}
    >
      { children }
    </div>
  )
}
  • 獲取根元素dom(root)妓美,然后進行翻轉(zhuǎn)。
    注意:這里為什么不能獲取html或者body標簽來進行翻轉(zhuǎn)呢鲤孵?
    因為通過html壶栋、body在翻轉(zhuǎn)會影響到modle彈框以及message的翻轉(zhuǎn),這個導致了很嚴重的問題普监,不說解決不了贵试,因為沒必要。
if(locale === 'he-IL' || locale === 'ar-EG') {
  const domeRoot = document.getElementById('root');
  domeRoot.style.transform="scaleX(-1)";
}
  • 在頁面中引用FlipBox組件凯正,然后包裹需要翻轉(zhuǎn)的圖片和文字
    <div className={styles.formItemTitle}>
      <FlipBox>我的滑板鞋毙玻,時尚時尚最時尚 {''}</FlipBox>
      <FlipBox>
            <img className={styles.modalImg} src={imgList.bills} alt="" />
      </FlipBox>
    </div>

這種方式可以實現(xiàn)圖片和文字的正常顯示±壬ⅲ看似結(jié)束了桑滩,好像完美解決了。但是我們忽略了input這個標簽
input經(jīng)過root的transform翻轉(zhuǎn)和自身的transform翻轉(zhuǎn)后會回復到之前的狀態(tài)允睹,簡單來說負負的正运准。還是LTR布局格式,所以還要借助direction特定對input(這里的input是antd中的缭受,原理一樣)設(shè)定一個rtl來適配胁澳。

  export const isLeftType = locale !== 'he-IL' && locale !== 'ar-EG';
    <FlipBox>
      <input 
        dir={isLeftType ? "ltr" : "rtl"}
        value={value}
        onChange={onChange}/>
    </FlipBox>

這里可以解決input的RTL適配。
當前頁面為狀態(tài)頁面的時候米者,可能存在LTR布局和RTL布局無差異的情況韭畸,這個時候可以通過transform: scaleX(-1)把整個頁面翻轉(zhuǎn)回來,這樣可以做到減少入侵代碼蔓搞,提高代碼的可讀性胰丁。
transform: scaleX(-1)方案來解決RTL布局的適配優(yōu)缺點都很明顯
優(yōu)點:
1、transform翻轉(zhuǎn)是兼容原來的css和js邏輯的喂分。翻轉(zhuǎn)后margin-left: 10px;在瀏覽器的理解下是向右的锦庸,而direction 方案只是針對 CSS,JS 邏輯需要調(diào)整兼容妻顶。
2酸员、transform不需要考慮 CSS 命名,CDN 部署等一系列工程問題讳嘱,因為它是劃分 CSS 作用域的方式幔嗦,針對 LTR/RTL 布局進行隔離適配。
3沥潭、內(nèi)嵌樣式 transform 方案也可以很好地做到兼容邀泉,而 direction 方案是針對 CSS 文件的,如果要針對 html 文件則需要另外額外的工作钝鸽。
缺點:
1汇恤、transform 翻轉(zhuǎn)的方案,需要嵌入很多入侵業(yè)務(wù)的代碼拔恰,耦合度較高因谎,復用性較低。如果頁面復雜颜懊,不建議使用這種方案财岔。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市河爹,隨后出現(xiàn)的幾起案子匠璧,更是在濱河造成了極大的恐慌,老刑警劉巖咸这,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夷恍,死亡現(xiàn)場離奇詭異,居然都是意外死亡媳维,警方通過查閱死者的電腦和手機酿雪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來侄刽,“玉大人执虹,你說我怎么就攤上這事∵肜妫” “怎么了袋励?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長当叭。 經(jīng)常有香客問我茬故,道長,這世上最難降的妖魔是什么蚁鳖? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任磺芭,我火速辦了婚禮,結(jié)果婚禮上醉箕,老公的妹妹穿的比我還像新娘钾腺。我一直安慰自己徙垫,他們只是感情好,可當我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布放棒。 她就那樣靜靜地躺著姻报,像睡著了一般。 火紅的嫁衣襯著肌膚如雪间螟。 梳的紋絲不亂的頭發(fā)上吴旋,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天,我揣著相機與錄音厢破,去河邊找鬼荣瑟。 笑死,一個胖子當著我的面吹牛摩泪,可吹牛的內(nèi)容都是我干的笆焰。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼见坑,長吁一口氣:“原來是場噩夢啊……” “哼仙辟!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鳄梅,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤叠国,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后戴尸,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體粟焊,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年孙蒙,在試婚紗的時候發(fā)現(xiàn)自己被綠了项棠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡挎峦,死狀恐怖香追,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情坦胶,我是刑警寧澤透典,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站顿苇,受9級特大地震影響峭咒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜纪岁,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一凑队、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧幔翰,春花似錦漩氨、人聲如沸西壮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽款青。三九已至,卻和暖如春赋访,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背缓待。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工蚓耽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人旋炒。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓步悠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瘫镇。 傳聞我的和親對象是個殘疾皇子鼎兽,可洞房花燭夜當晚...
    茶點故事閱讀 44,724評論 2 354

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

  • 選擇qi:是表達式 標簽選擇器 類選擇器 屬性選擇器 繼承屬性: color,font铣除,text-align谚咬,li...
    love2013閱讀 2,314評論 0 11
  • 背景 阿拉伯語適配是一個比較麻煩的事情,不止在于它文案的適配尚粘,更多的是在于其語言習慣的變化择卦。由從左到右(LeftT...
    小笨狼閱讀 14,200評論 23 40
  • 本文轉(zhuǎn)載自:眾成翻譯譯者:哈呼哈哈呼鏈接:http://www.zcfy.cc/article/2321原文:ht...
    極樂君閱讀 2,994評論 0 9
  • Mobile Web Favorites 參與貢獻 移動前端開發(fā)收藏夾,歡迎使用Issues以及 Pull Req...
    柴東啊閱讀 734評論 0 2
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5郎嫁? 答:HTML5是最新的HTML標準秉继。 注意:講述HT...
    kismetajun閱讀 27,485評論 1 45