問題一:
ios微信表單填寫時鹅很,點擊之后表單被放大:
解決:在<meta>
增加user-scalable:允許使用者縮放逃沿,1 or 0 (yes or no)
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
問題二:
ios微信返回時盛嘿,會從緩存直接加載舊頁面鹿鳖,有些事件不會再觸發(fā)俄讹,舊頁面一些標志也沒有重置惹想,會出現(xiàn)幾個組件重疊。
- 解決:在二級頁面的生命周期的
destroy
周期森爽,放一個鍵值對到sessionstroage
,返回是從sessionstroage
中拿出這個值嚣镜,如果這個值存在爬迟,執(zhí)行reload()
函數(shù)。 - 另一種思路:
//通過pageshow事件決定是否需要刷新頁面
window.addEventListener('pageshow', function(e) {
// 通過persisted屬性判斷是否存在 BF Cache
if (e.persisted) {
location.reload();
}
});
問題三:
Angular-cli搭建種子工程無法在微信瀏覽器中打開菊匿。
解決:查看polyfills.ts文件付呕,解注釋:
/** IE9, IE10 and IE11 requires all of the following polyfills. **/
import 'core-js/es6/symbol';
import 'core-js/es6/object';
import 'core-js/es6/function';
import 'core-js/es6/parse-int';
import 'core-js/es6/parse-float';
import 'core-js/es6/number';
import 'core-js/es6/math';
import 'core-js/es6/string';
import 'core-js/es6/date';
import 'core-js/es6/array';
import 'core-js/es6/regexp';
import 'core-js/es6/map';
import 'core-js/es6/weak-map';
import 'core-js/es6/set';
在說這個問題之前要先搞清楚2件事,一是微信瀏覽器的內(nèi)核究竟是什么跌捆,二是polyfills.ts這個文件有什么用徽职。
- 關(guān)于瀏覽器內(nèi)核,一個騰訊內(nèi)部人員說微信6.1版本以上的android用戶佩厚,都是使用的QQ瀏覽器的X5內(nèi)核姆钉。5.4-6.1之間的版本,若用戶安裝了QQ瀏覽器就是使用的X5內(nèi)核抄瓦,若用戶未安裝瀏覽器潮瓶,使用的是系統(tǒng)內(nèi)核(微信瀏覽器到底是什么內(nèi)核?)钙姊。X5內(nèi)核在今年4月份毯辅,(Android)已經(jīng)全面升級為Blink內(nèi)核(Blink引擎基于WebKit2——蘋果公司于2010年推出的新的WebKit引擎)。而ios版本一直使用的是safari的內(nèi)核煞额,也就是webkit思恐。所以現(xiàn)在微信內(nèi)置的瀏覽器的內(nèi)核整體來說是比較統(tǒng)一的,但是微信魔改之后的Blink內(nèi)核與chrome內(nèi)核有所差異膊毁,所以在chrome調(diào)試之后放到微信還是會出現(xiàn)一些問題胀莹,就例如上面那個問題,Angular項目跑不動婚温。
- 關(guān)于polyfills.ts嗜逻,文檔中有詳細介紹。由于各個瀏覽器的javascript引擎有所差異缭召,可以polyfills中導(dǎo)入一些兼容的包栈顷,實現(xiàn)瀏覽器缺失的某些javascript特性逆日。
結(jié)論:微信瀏覽器內(nèi)核可能不支持es6的新特新或者不支持其中的某個特性,把相應(yīng)的包填充進去之后就能正常運行了萄凤。(感覺脫去了IE6的帽子之后又扣上了IE9的帽子室抽。。)