问题一:
ios微信表单填写时,点击之后表单被放大:
解决:在<meta>
增加user-scalable:允许使用者缩放,1 or 0 (yes or no)
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=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这个文件有什么用。
- 关于浏览器内核,一个腾讯内部人员说微信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项目跑不动。
- 关于polyfills.ts,文档中有详细介绍。由于各个浏览器的javascript引擎有所差异,可以polyfills中导入一些兼容的包,实现浏览器缺失的某些javascript特性。
结论:微信浏览器内核可能不支持es6的新特新或者不支持其中的某个特性,把相应的包填充进去之后就能正常运行了。(感觉脱去了IE6的帽子之后又扣上了IE9的帽子。。)