详解一次Vue低版本安卓白屏问题的解决过程


Posted in Javascript onMay 30, 2019

因为业务需要一定要使用安卓4.4的webview浏览页面,测试的时候发生了白屏问题,很自然想到使用babel转换部分ES6语法.

Babel 转换 Promise 和 Symbol ES6语法的配置

# 两项都需要放到生产依赖
npm install babel-polyfill --save
npm install es6-promise --save
// main.js
import 'babel-polyfill';
import Es6Promise from 'es6-promise';

Es6Promise.polyfill();
// babel.config.js

process.env.VUE_CLI_BABEL_TRANSPILE_MODULES = true;

module.exports = {
 presets: [
  [
   '@vue/app',
   {
    useBuiltIns: 'entry',
    polyfills: [
     'es6.promise',
     'es6.symbol',
    ],
   },
  ],
 ],
 plugins,
};
// 使用vue cli3构建的vue项目
// vue.config.js
module.exports = {
 transpileDependencies: ['webpack-dev-server/client'],
 chainWebpack: (config) => {
 config.entry.app = ['babel-polyfill', './src/main.js'];
 }
}

但结果还是白屏,那么决定使用Babel把语法转换成安卓4.4以上,应该没有问题了。

// .browserslistrc
>= 1%
last 1 major version
not dead
Android >= 4.4

不同运行环境下的严格模式

结果还是白屏,查阅众多网络文章,同样没有很好的答案...

百思不得其解,无奈之下在 Android Studio 上下载了个4.4的模拟器,在内置浏览器上打开页面,使用 Chrome 远程调试 Android 上的浏览器, 在 Chrome 上地址栏输入 chrome://inspect/#devices 选择相应模拟器设备的 inspect 就会弹出 console 调试。

没想到发现报错是 Uncaught SyntaxError: Duplicate data property in object literal not allowed in strict mode ,意思是在严格模式下的对象里不能重复定义相同属性,但是这在现代浏览器(Chrome)的严格模式上运行是没有问题的,其结果是后定义的属性值会覆盖前定义的属性值,例如:

'use strict'
var test = {
 a: 1,
 a: 2,
}
// 结果test会定义成 => {a: 2}

但是为什么会这样呢,在打包后的报错js文件里将其格式化后发现是组件的属性重复定义了,

<van-nav-bar
 title="标题"
 left-text="返回"
 right-text="按钮"
 left-arrow
 @click-left="onClickLeft"
 @click-right="onClickRight"
 :left-arrow="true"
/>

我的项目里 Vant 的 left-arrow 被我重复定义了,组件会被转义成js:

详解一次Vue低版本安卓白屏问题的解决过程

所以说不同运行环境的严格模式还是会有不一样的结果,

在网上查了下资料总结了严格模式下的几种错误:

1. 我上面遇到的对象属性重复定义

2. 在函数声明中相同的参数名

SyntaxError: Strict mode function may not have duplicate parameter names.

例如:

function fix(a,b,a) {   
   return a+b;   
 }

3. 用前导0声明8进制直接量

SyntaxError: Octal literals are not allowed in strict mode.

var a = 012;

4. 在eval中声明变量、重新声明、删除或重写eval和arguments这两个标示符

SyntaxError: Assignment to eval or arguments is not allowed in strict mode.

例如:

'use strict';
eval('var foo = 2');

5. 用delete删除显示声明的标识符、名称和具名函数

SyntaxError: Delete of an unqualified identifier in strict mode.

例如:

function temp() { 
 'use strict'; 
 var test = 1; 
 delete test; 
}

6. 代码中使用扩展的保留字,例如 interface , let , yield , package , private 等

SyntaxError: Unexpected strict mode reserved word

7. 使用了 with

SyntaxError: Strict mode code may not include a with statement

8. 函数中不可访问caller、callee以及arguments

例如:

function foo(){
 'use strict';
 foo.caller;  // TypeError
 foo.arguments; // TypeError
 arguments.callee; // TypeError
}
foo();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
图片自动缩小的js代码,用以防止图片撑破页面
Mar 12 Javascript
HTML页面滚动时获取离页面顶部的距离2种实现方法
Sep 05 Javascript
jQuery实现的向下图文信息滚动效果
May 03 Javascript
Vue-Router实现页面正在加载特效方法示例
Feb 12 Javascript
JS实现留言板功能
Jun 17 Javascript
Node.js dgram模块实现UDP通信示例代码
Sep 26 Javascript
vue项目设置scrollTop不起作用(总结)
Dec 21 Javascript
详解vue-cli@2.x项目迁移日志
Jun 06 Javascript
JS实现的碰撞检测与周期移动完整示例
Sep 02 Javascript
简单了解JS打开url的方法
Feb 21 Javascript
vue-resource post数据时碰到Django csrf问题的解决
Mar 13 Javascript
Echarts如何重新渲染实例详解
May 30 Javascript
基于iview的router常用控制方式
May 30 #Javascript
深入了解js原型模式
May 30 #Javascript
js逆向解密之网络爬虫
May 30 #Javascript
Vue.js中的组件系统
May 30 #Javascript
Vue+Django项目部署详解
May 30 #Javascript
了解重排与重绘
May 29 #Javascript
小程序如何构建骨架屏
May 29 #Javascript
You might like
大师制作的中短波矿石收音机
2020/04/02 无线电
main.php
2006/12/09 PHP
PHP syntax error, unexpected $end 错误的一种原因及解决
2008/10/25 PHP
获取URL文件名后缀
2013/10/24 PHP
PHP编程风格规范分享
2014/01/15 PHP
JavaScript 图片预览效果 推荐
2009/12/22 Javascript
jQuery之end()和pushStack()使用介绍
2012/02/07 Javascript
JS跨域问题详解
2014/11/25 Javascript
深入分析Javascript跨域问题
2015/04/17 Javascript
IE6兼容透明背景图片及解决方案
2015/08/19 Javascript
jQuery实现两款有动画功能的导航菜单代码
2015/09/16 Javascript
jquery获取css的color值返回RGB的方法
2015/12/18 Javascript
分享10个优化代码的CSS和JavaScript工具
2016/05/11 Javascript
浅析JavaScript 箭头函数 generator Date JSON
2016/05/23 Javascript
JavaScript使用键盘输入控制实现数字验证功能
2016/08/19 Javascript
Vue2.0基于vue-cli+webpack同级组件之间的通信教程(推荐)
2017/09/14 Javascript
浅谈Angular文字折叠展开组件的原理分析
2017/11/24 Javascript
Vue 实现登录界面验证码功能
2020/01/03 Javascript
Python3.5 Json与pickle实现数据序列化与反序列化操作示例
2019/04/29 Python
详解PyCharm安装MicroPython插件的教程
2019/06/24 Python
Django中自定义查询对象的具体使用
2019/10/13 Python
python函数装饰器之带参数的函数和带参数的装饰器用法示例
2019/11/06 Python
HTML5 canvas基本绘图之填充样式实现
2016/06/27 HTML / CSS
Boda Skins皮衣官网:奢侈皮夹克,全球配送
2016/12/15 全球购物
性能服装:HYLETE
2018/08/14 全球购物
瑞典的玛丽小姐:Miss Mary of Sweden
2019/02/13 全球购物
临床医师专业个人自我评价范文
2013/11/07 职场文书
浙江文明网签名寄语
2014/01/18 职场文书
英文商务邀请信
2014/01/22 职场文书
2014优秀大学生简历自我评价
2014/09/15 职场文书
2015年乡镇纪检工作总结
2015/04/22 职场文书
幼儿园家长工作总结2015
2015/04/25 职场文书
苦儿流浪记读书笔记
2015/07/01 职场文书
浅谈如何提高PHP代码的质量
2021/05/28 PHP
MySQL笔记 —SQL运算符
2022/01/18 MySQL
macos系统如何实现微信双开? mac登录两个微信以上微信的技巧
2022/07/23 数码科技