<code id="6mcsu"></code>
<li id="6mcsu"></li>
<li id="6mcsu"><dl id="6mcsu"></dl></li>
  • <code id="6mcsu"><tr id="6mcsu"></tr></code>
    或者

    分享一下寫移動適配規(guī)則的技巧

    作者:長瘦不老i 瀏覽:273 發(fā)布時間:2018-04-03
    分享 評論 0

      經(jīng)??吹接腥颂釂栒f,移動適配規(guī)則到底怎么寫?為什么我的適配失敗?當(dāng)然適配失敗情況有多種,其實(shí)很多還是因?yàn)檫m配規(guī)則沒寫對。今天我就來說一說適配規(guī)則的寫法。


      說到移動適配,首先必須要提到的一個概念就是“正則表達(dá)式”,所以上面說,對于懂點(diǎn)技術(shù)的人來說,可能都懂點(diǎn)正則表達(dá)式,對于不懂的人來說,正則表達(dá)式就是個很復(fù)雜的東西(其實(shí)對于懂的人來說也很復(fù)雜),但很慶幸的是,移動適配所需要了解的正則表達(dá)式知識很簡單。


      對于不懂正則表達(dá)式的人來說,可能不知道這是個什么東西,但你應(yīng)該知道另一個概念叫“通配符”,通配符大家應(yīng)該都了解,比如中學(xué)時老師就教我們說,你在windows搜索時,使用“*.jpg”就是搜索所有jpg的圖片,因?yàn)樾翘枴?”表示匹配任意個字符,現(xiàn)在暫且不說通配符和正則表達(dá)式的區(qū)別,你只要知道,反正不管通配符或正則表達(dá)式都是用來文本匹配的就行了。


      正則表達(dá)式和通配符一樣,不同的字符表示不同的含義,比如:


      代碼說明


      .匹配除換行符以外的任意字符


      \w匹配字母或數(shù)字或下劃線或漢字


      \s匹配任意的空白符


      \d匹配數(shù)字


      \b匹配單詞的開始或結(jié)束


      ^匹配字符串的開始


      $匹配字符串的結(jié)束


      當(dāng)然還有很多其它的,而且不同的組合方式會匹配出非常復(fù)雜的文本。


      但對于百度移動適配,實(shí)際上就是利用正則表達(dá)式來替換PC和移動URL中動態(tài)可替換的一些參數(shù)。


      比如:PC頁面URL為:www.baidu.com/1.html,移動頁面URL為:m.baidu.com/1.html,其中的數(shù)字1就是可替換的動態(tài)參數(shù),因?yàn)樗赡茏兂?、3、4等又是另外的頁面了。所以我們就可以用:www.baidu.com/(\d+).html,以此來匹配www.baidu.com/{這里是數(shù)字}.html的所有頁面。移動頁面URL直接用${1},${2},……來表示這個鏈接被替換了多少個參數(shù)即可,所以我們該移動頁面URL規(guī)則為:m.baidu.com/${1}.html


      其中\(zhòng)d 就表示匹配一個數(shù)字,\d+ 由于多了個加號,就表示匹配多個數(shù)字。


      同理,比如:PC頁面URL為:www.baidu.com/a.html,移動頁面URL為:m.baidu.com/a.html,其中的字母a就是可替換的動態(tài)參數(shù),因?yàn)樗赡茏兂蒪、c、d等又是另外的頁面了。所以我們就可以用:www.baidu.com/([a-zA-Z]+).html,以此來匹配www.baidu.com/{這里是字母}.html的所有頁面。同樣,我們該移動頁面URL規(guī)則還是為:m.baidu.com/${1}.html


      其中[a-zA-Z]就表示匹配一個字母,[a-zA-Z]+ 由于多了個加號,就表示匹配多個字母。


      當(dāng)然你會想,正則表達(dá)式這么復(fù)雜,我要遇到很復(fù)雜的URL該怎么匹配,其實(shí),百度現(xiàn)在僅僅只支持簡單的幾個正則表達(dá)式:


      a)確定都是數(shù)字的,則用 (\d+)表示


      b)確定都是字母的,則用 ([a-zA-Z]+) 表示


      c)確定是字母數(shù)字混合,則用 ([a-zA-Z0-9]+) 表示


      d)確定是字母數(shù)字下劃線混合,則用 (\w+) 表示


      只有在pattern的粒度無法用上述a和b形式表示時,才用c形式表示;


      只有在pattern粒度無法用a、b、c表示時,則才用d形式表示。


      如果這4種規(guī)則都無法滿足你的需求,那很不幸的告訴你,你就只能試用URL適配了。


      如果你還是對移動適配規(guī)則寫法不太懂,那可以參考百度站長學(xué)院的移動適配工具幫助,再看我這篇文章,你應(yīng)該會有一個深的了解。


    国产中文字幕在线| 国产精品无码专区在线观看| 毛片无码免费无码播放| 超清无码无卡中文字幕| 国产精品无码无片在线观看| 麻豆AV无码精品一区二区 | 无码精品国产dvd在线观看9久| 东京热加勒比无码少妇| 日韩AV高清无码| 中文字幕亚洲精品资源网| 无码精品蜜桃一区二区三区WW| 亚洲av中文无码乱人伦在线咪咕| 最近最新高清免费中文字幕| 欧美日韩亚洲中文字幕一区二区三区 | 亚洲国产人成中文幕一级二级| 少妇人妻综合久久中文字幕| 精品人妻大屁股白浆无码 | 18禁网站免费无遮挡无码中文| 精品人妻系列无码一区二区三区 | 中文字幕乱妇无码AV在线| 台湾佬中文娱乐中文| 亚洲国产a∨无码中文777| 在线观看无码AV网站永久免费| 国产成人无码专区| 国产V片在线播放免费无码| 97免费人妻无码视频| 国产亚洲AV无码AV男人的天堂| 久久久久无码精品国产不卡| 亚洲av无码av制服另类专区| 亚洲精品无码高潮喷水在线| 中文字幕AV中文字无码亚| 亚洲av午夜国产精品无码中文字 | 成年无码av片完整版| 国产又爽又黄无码无遮挡在线观看| 日韩中文久久| 中文字幕无码成人免费视频| 中文字幕精品无码一区二区| 久久亚洲AV成人无码| 中文字幕人妻无码一夲道| 未满小14洗澡无码视频网站| 免费A级毛片无码专区|