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 相关文章推荐
基于js disabled="false"不起作用的解决办法
Jun 26 Javascript
css配合jquery美化 select
Nov 29 Javascript
两个多选select(multiple左右)添加、删除选项和取值实例
May 12 Javascript
如何编写高质量JS代码
Dec 28 Javascript
js用拖动滑块来控制图片大小的方法
Feb 27 Javascript
JavaScript实现的链表数据结构实例
Apr 02 Javascript
JavaScript实现in-place思想的快速排序方法
Aug 07 Javascript
JS动态遍历json中所有键值对的方法(不知道属性名的情况)
Dec 28 Javascript
基于AGS JS开发自定义贴图图层
Mar 31 Javascript
webpack中使用iconfont字体图标的方法
Feb 22 Javascript
基于webpack4搭建的react项目框架的方法
Jun 30 Javascript
js get和post请求实现代码解析
Feb 06 Javascript
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语法速查表
2007/01/02 PHP
PHP读取、解析eml文件及生成网页的方法示例
2017/09/04 PHP
对textarea框的代码调试,而且功能上使用非常方便,酷
2006/06/30 Javascript
学习ExtJS Column布局
2009/10/08 Javascript
Javascript 二维数组
2009/11/26 Javascript
关于javascript DOM事件模型的两件事
2010/07/22 Javascript
EXTJS记事本 当CompositeField遇上RowEditor
2011/07/31 Javascript
js将当前时间格式转换成时间搓(自写)
2013/09/26 Javascript
不使用jquery实现js打字效果示例分享
2014/01/19 Javascript
使表格的标题列可左右拉伸jquery插件封装
2014/11/24 Javascript
jquery实现侧边弹出的垂直导航
2014/12/09 Javascript
JS实现CheckBox复选框全选全不选功能
2015/05/06 Javascript
Node.js的文件权限及读写flag详解
2016/10/11 Javascript
js实现下一页页码效果
2017/03/07 Javascript
微信小程序 flex实现导航实例详解
2017/04/26 Javascript
Vue.js鼠标悬浮更换图片功能
2017/05/17 Javascript
详解JavaScript中的六种错误类型
2017/09/21 Javascript
vue cli2.0单页面title修改方法
2018/06/07 Javascript
微信小程序pinker组件使用实现自动相减日期
2020/05/07 Javascript
elementui更改el-dialog关闭按钮的图标d的示例代码
2020/08/04 Javascript
python 数据清洗之数据合并、转换、过滤、排序
2017/02/12 Python
基于numpy.random.randn()与rand()的区别详解
2018/04/17 Python
win10下python3.5.2和tensorflow安装环境搭建教程
2018/09/19 Python
python算法题 链表反转详解
2019/07/02 Python
Python 离线工作环境搭建的方法步骤
2019/07/29 Python
Django 拆分model和view的实现方法
2019/08/16 Python
python快速排序的实现及运行时间比较
2019/11/22 Python
使用opencv识别图像红色区域,并输出红色区域中心点坐标
2020/06/02 Python
一套带答案的C++笔试题
2014/01/10 面试题
法学专业应届生求职信
2013/10/16 职场文书
社区反邪教工作方案
2014/06/16 职场文书
消防志愿者活动方案
2014/08/23 职场文书
2015年发展党员工作总结报告
2015/03/31 职场文书
销售经理助理岗位职责
2015/04/13 职场文书
Golang的继承模拟实例
2021/06/30 Golang
手把手教你导入Go语言第三方库
2021/08/04 Golang