前言:
近期嘗試對(duì)一個(gè)做過跳轉(zhuǎn)適配的dedecms/gbk手機(jī)站進(jìn)行整站mip改造,經(jīng)過一系列思路完善和測(cè)試,終于完成,回顧下過程,主要問題可分為以下幾類:
1、非utf-8站點(diǎn)的編碼問題
前些時(shí)候宋同學(xué)在站長社區(qū)發(fā)布了新裝utf-8版cms和轉(zhuǎn)換數(shù)據(jù)庫編碼的教程,我剛開始也是類似思路,但因?yàn)檎军c(diǎn)經(jīng)過二次開發(fā)以及包含一些亂七八糟的附加文件等,重裝cms很難復(fù)原之前的修改,此思路卒。后又嘗試在數(shù)據(jù)庫調(diào)用時(shí)以gbk編碼讀取,測(cè)試生成后雖大體上瀏覽正常,但還是存在些許后續(xù)問題和少部分亂碼,也放棄了該方案。最終,靈光一閃——為什么要在程序執(zhí)行過程中糾結(jié)?完全可以在生成靜態(tài)頁面時(shí)進(jìn)行替換整改啊!頓時(shí)柳暗花明之感油然而生,測(cè)試果然可行,之后遇到后續(xù)問題(如下面問題2、3)也因此思路而變得易解決了。
2、路徑問題,、/< mip-img>等標(biāo)簽中的相對(duì)路徑需均轉(zhuǎn)換為完整url,這個(gè)在目前教程里貌似沒有明確提出,根目錄相對(duì)路徑還好,主要是相對(duì)當(dāng)前頁面路徑轉(zhuǎn)換完整url需加上所在目錄有些難度(特別是標(biāo)簽調(diào)用生成的相對(duì)路徑,如分頁)。
3、內(nèi)聯(lián)樣式問題
模板里的內(nèi)聯(lián)樣式可以手動(dòng)整改,雖煩瑣但難度不大,主要問題在于后臺(tái)發(fā)布文章時(shí),cms編輯器會(huì)自動(dòng)生成包括內(nèi)聯(lián)樣式在內(nèi)的各種不符合mip規(guī)則的原始代碼,除了折騰一下對(duì)編輯器進(jìn)行修改,其他也很難解決了。
4、js問題
mip規(guī)范局限了js的使用,這個(gè)的確挺頭疼的,好在我改造的站點(diǎn)內(nèi)js不多,所以刪掉部分效果和使用現(xiàn)有組件替換,也湊合解決了此問題。不過還是希望百度mip團(tuán)隊(duì)能在考慮下此方面的規(guī)范方案優(yōu)化,不少站點(diǎn)有很多js代碼且不能去除,全部以組件形式提交也很費(fèi)事且需要一定的程序基礎(chǔ),其他問題還可以按統(tǒng)一教程去解決,但js上的mip改造卻無法如此,按照目前的限制會(huì)導(dǎo)致很多站長因此一點(diǎn)就不得不放棄mip改造。
5、其他小問題
·發(fā)現(xiàn)少部分樣式有沖突,需根據(jù)實(shí)際情況對(duì)本身css進(jìn)行局部修改。
·發(fā)現(xiàn)mip cache無法識(shí)別站點(diǎn)中圖片的302跳轉(zhuǎn),如原站使用302跳轉(zhuǎn)的圖片,mip生效后無法顯示圖片。該問題已和百度技術(shù)人員溝通,說后續(xù)可以考慮支持,目前我自己加了一段代碼對(duì)路徑做了下處理。
·組件使用bug(如mip-carousel多圖輪播圖片套鏈接會(huì)導(dǎo)致圖片顯示空白,且無法自適應(yīng)屏幕)。
·mip引入提交后就回顯個(gè)success,也沒有提交記錄和狀態(tài),用戶體驗(yàn)上有所欠缺。