总结几个Angular2与ios wechat的问题

问题一:

ios微信表单填写时,点击之后表单被放大:

解决:在增加user-scalable:允许使用者缩放,1 or 0 (yes or no)


问题二:

ios微信返回时,会从缓存直接加载旧页面,有些事件不会再触发,旧页面一些标志也没有重置,会出现几个组件重叠。

  • 解决:在二级页面的生命周期的destroy周期,放一个键值对到sessionstroage,返回是从sessionstroage中拿出这个值,如果这个值存在,执行reload()函数。
  • 另一种思路:
//通过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件事,一是微信浏览器的内核究竟是什么,二是polyfills.ts这个文件有什么用。

  1. 关于浏览器内核,一个腾讯内部人员说微信6.1版本以上的android用户,都是使用的QQ浏览器的X5内核。5.4-6.1之间的版本,若用户安装了QQ浏览器就是使用的X5内核,若用户未安装浏览器,使用的是系统内核(微信浏览器到底是什么内核?)。X5内核在今年4月份,(Android)已经全面升级为Blink内核(Blink引擎基于WebKit2——苹果公司于2010年推出的新的WebKit引擎)。而ios版本一直使用的是safari的内核,也就是webkit。所以现在微信内置的浏览器的内核整体来说是比较统一的,但是微信魔改之后的Blink内核与chrome内核有所差异,所以在chrome调试之后放到微信还是会出现一些问题,就例如上面那个问题,Angular项目跑不动。
  2. 关于polyfills.ts,文档中有详细介绍。由于各个浏览器的javascript引擎有所差异,可以polyfills中导入一些兼容的包,实现浏览器缺失的某些javascript特性。

结论:微信浏览器内核可能不支持es6的新特新或者不支持其中的某个特性,把相应的包填充进去之后就能正常运行了。(感觉脱去了IE6的帽子之后又扣上了IE9的帽子。。)

你可能感兴趣的:(总结几个Angular2与ios wechat的问题)