vue 解决IOS10低版本白屏的问题


Posted in Javascript onNovember 17, 2020

新公司是做自己的独立产品,比之前呆过的外包公司要求严格的多,注重用户体验,以下是在新项目里进行前端优化的一些操作

一,低版本空白屏问题,以及ios8的样式问题

本项目是通过vue-cli搭建,上线以后运行在新版本的苹果手机和安卓手机上均无问题。但是在ios8 9上出现了空白屏的原理,经过测试以后发现是低版本不兼容es6的语法,经过几番尝试找到了最优解。

1 空白屏问题

首先安装babel-polyfill,安装命令:npm install --save-dev babel-polyfill

安装成功后找到webpack.base.conf里把第16行的代码换成第17行的写法,如图1所示

vue 解决IOS10低版本白屏的问题

相同的页面,加入红色方框里的代码,如图2所示

{
  test: /\.js$/,
  exclude: /node_modules/,
  loader: "babel-loader"
  },

vue 解决IOS10低版本白屏的问题

2 样式问题

找到webpack.prod.conf文件,将注释代码替换成红色方框内的代码即可,如图3

vue 解决IOS10低版本白屏的问题

二 打包之后的文件以及生成的vendor文件过大的问题

1打包文件过大的问题

找到config底下的index.js文件,在69行的代码productionSourceMap:true,将true改为false。不然在最终打包的文件中会出现一些map文件,map文件的作用在于:项目打包后,代码都是经过压缩加密的,如果运行时报错,输出的错误信息无法准确得知是哪里的代码报错。有了map就可以像未加密的代码一样,准确的输出是哪一行哪一列有错。但是这里为了瘦身大业,可以舍去。

2生成的vendor文件过大的问题

vendor文件里会将项目中vue vue-router mint-ui element-ui等库和框架一起打包压缩,这样必定会占用空间,造成压缩包过大。通常都有好几百k至少超过1M,在加载页面的时候会极度耗时。

这里建议使用cdn 然后在build里找到webpack.base.conf,加入平常不改动的库,如图4所示,然后在入口页面index.html导入相应的cdn

vue 解决IOS10低版本白屏的问题

同时要在项目里把诸如图5这样的导入都去除,否则打包的时候依然会占用空间,我项目里这样优化之后,vendor大小由239k优化到10k,减小的20倍

vue 解决IOS10低版本白屏的问题

三 压缩图片 ,推荐一个压缩图片的工具 https://tinypng.com/

如果有更改好的工具可以留言告知~

补充知识:vue-cli构建的移动端项目ios9以下打开页面空白问题

造成ios9一下页面空白问题,个人遇到的是项目npm run build之后,项目里es6没有转成es5造成的。

vue-cli构建的本身已经配置好babel,es6的转码,但是还遇到这个问题。

那么可能的原因是引入的文件没有转码,像我个人把http.js写在了static/js/http.js里了。 在static这个文件夹下。项目编译这个文件本身不打包。所有写在这里的es6没有转成es5.

所有要把js文件移入src下的assets,或者自建的文件夹

ios9以下页面空白如果是其他方面引起的可以考虑在pc端IE浏览器的Edge调试。把错误都排除了,能够页面显示出来,那么基本就成功了。

IE会报vuex requires a Promise polyfill in this browser这个错误,成这种现象的原因归根究底就是浏览器对ES6中的promise无法支持,因此需要通过引入babel-polyfill来是我们的浏览器正常使用es6的功能

解决办法:安装babel-polyfill这个依赖 cnpm install ?save-dev babel-polyfill

然后在build下的webpack.base.conf.js文件中,使用

const webpackConfig = {
 context: path.resolve(__dirname, '../'),
 entry: {
  app: ["babel-polyfill", "./src/main.js"]
 }

以上这篇vue 解决IOS10低版本白屏的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript中Math对象使用说明
Jan 16 Javascript
简洁短小的 JavaScript IE 浏览器判定代码
Mar 21 Javascript
Js中的onblur和onfocus事件应用介绍
Aug 27 Javascript
js操作输入框中选择内容兼容IE及其他主流浏览器
Apr 22 Javascript
javascript常见用法总结
May 22 Javascript
JavaScript实现同一页面内两个表单互相传值的方法
Aug 12 Javascript
javascript日期格式化方法汇总
Oct 04 Javascript
AngularJS表格添加序号的方法
Mar 03 Javascript
VueCli4项目配置反向代理proxy的方法步骤
May 17 Javascript
详解JSON.stringify()的5个秘密特性
May 26 Javascript
JavaScript事件委托实现原理及优点进行
Aug 29 Javascript
vue-cropper组件实现图片切割上传
May 27 Vue.js
JavaScript枚举选择jquery插件代码实例
Nov 17 #jQuery
html中创建并调用vue组件的几种方法汇总
Nov 17 #Javascript
解决vue项目中出现Invalid Host header的问题
Nov 17 #Javascript
vue的webcamjs集成方式
Nov 16 #Javascript
SpringBoot在yml配置文件中配置druid的操作
Nov 16 #Javascript
详解JavaScript原型与原型链
Nov 16 #Javascript
详解JavaScript执行模型
Nov 16 #Javascript
You might like
php实现文件与16进制相互转换的方法示例
2017/02/16 PHP
PHP简单实现合并2个数字键数组值的方法
2017/05/30 PHP
Laravel框架实现抢红包功能示例
2019/10/31 PHP
使用Mootools动态添加Css样式表代码,兼容各浏览器
2011/12/12 Javascript
js固定DIV高度,超出部分自动添加滚动条的简单方法
2013/07/10 Javascript
纯Javascript实现Windows 8 Metro风格实现
2013/10/15 Javascript
node.js中的fs.lchownSync方法使用说明
2014/12/16 Javascript
javascript结合fileReader 实现上传图片
2015/01/30 Javascript
jquery实现上下左右滑动的方法
2015/02/09 Javascript
jquery 实现输入邮箱时自动补全下拉提示功能
2015/10/04 Javascript
js日期相关函数dateAdd,dateDiff,dateFormat等介绍
2016/09/24 Javascript
jQuery实现点击任意位置弹出层外关闭弹出层效果
2016/10/19 Javascript
arcgis for js 修改infowindow样式的方法
2016/11/02 Javascript
jQuery Form表单取值的方法
2017/01/11 Javascript
VS Code转换大小写、修改选中文字或代码颜色的方法
2017/12/15 Javascript
转换layUI的数据表格中的日期格式方法
2019/09/19 Javascript
vue中的使用token的方法示例
2020/03/10 Javascript
写给新手同学的vuex快速上手指北小结
2020/04/14 Javascript
微信小程序实现选择地址省市区三级联动
2020/06/21 Javascript
javascript实现前端成语点击验证优化
2020/06/24 Javascript
[00:32]2018DOTA2亚洲邀请赛Liquid出场
2018/04/03 DOTA
[34:44]Liquid vs TNC Supermajor 胜者组 BO3 第二场 6.4
2018/06/05 DOTA
python连接mysql调用存储过程示例
2014/03/05 Python
Python程序员面试题 你必须提前准备!(答案及解析)
2018/01/23 Python
Python读取txt某几列绘图的方法
2018/10/14 Python
Django 开发调试工具 Django-debug-toolbar使用详解
2019/07/23 Python
Python3的socket使用方法详解
2020/02/18 Python
Django中使用Json返回数据的实现方法
2020/06/03 Python
python如何使用腾讯云发送短信
2020/09/17 Python
在c#中using和new这两个关键字有什么意义
2013/05/19 面试题
优秀班组事迹材料
2014/12/24 职场文书
工厂采购员岗位职责
2015/04/07 职场文书
总经理司机岗位职责
2015/04/10 职场文书
python实现自定义日志的具体方法
2021/05/28 Python
css常用字体属性与背景属性介绍
2022/02/28 HTML / CSS
SQL Server中常用截取字符串函数介绍
2022/03/16 SQL Server