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 相关文章推荐
GreyBox技术总结(转)
Nov 23 Javascript
js+JQuery返回顶部功能如何实现
Dec 03 Javascript
JS注释所产生的bug 即使注释也会执行
Nov 19 Javascript
浅谈JavaScript数据类型及转换
Feb 28 Javascript
如何用js实现鼠标向上滚动时浮动导航
Jul 18 Javascript
jquery过滤特殊字符',防sql注入的实现方法
Aug 17 Javascript
Javascript 普通函数和构造函数的区别
Nov 05 Javascript
从parcel.js打包出错到选择nvm的全部过程
Jan 23 Javascript
jQuery length 和 size()区别总结
Apr 26 jQuery
Vue 路由切换时页面内容没有重新加载的解决方法
Sep 01 Javascript
vue+axios+promise实际开发用法详解
Oct 15 Javascript
js实现计算器功能
Aug 10 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程序中的常见漏洞进行攻击
2006/10/09 PHP
php实现根据url自动生成缩略图的方法
2014/09/23 PHP
php快速导入大量数据的实例方法
2019/09/23 PHP
JAVASCRIPT style 中visibility和display之间的区别
2010/01/22 Javascript
JQuery扩展插件Validate—6 radio、checkbox、select的验证
2011/09/05 Javascript
jquery easyui滚动条部分设置介绍
2013/09/12 Javascript
javaScript如何处理从java后台返回的list
2014/04/24 Javascript
深入理解JavaScript系列(22):S.O.L.I.D五大原则之依赖倒置原则DIP详解
2015/03/05 Javascript
jQuery实现带动画效果的二级下拉导航方法
2015/03/11 Javascript
测试IE浏览器对JavaScript的AngularJS的兼容性
2015/06/19 Javascript
Jsonp post 跨域方案
2015/07/06 Javascript
浅析四种常见的Javascript声明循环变量的书写方式
2015/10/14 Javascript
JS实现简单的右下角弹出提示窗口完整实例
2016/06/21 Javascript
基于JS实现横线提示输入验证码随验证码输入消失(js验证码的实现)
2016/10/27 Javascript
纯JS实现表单验证实例
2016/12/24 Javascript
Easyui在treegrid添加控件的实现方法
2017/06/23 Javascript
React组件refs的使用详解
2018/02/09 Javascript
微信小程序实现保存图片到相册功能
2018/11/30 Javascript
Vue侦测相关api的实现方法
2019/05/22 Javascript
javascript 构建模块化开发过程解析
2019/09/11 Javascript
jQuery 选择器用法实例分析【prev + next】
2020/05/22 jQuery
Python根据欧拉角求旋转矩阵的实例
2019/01/28 Python
浅谈Python爬虫基本套路
2019/03/25 Python
python设置环境变量的作用和实例
2019/07/09 Python
浅析pip安装第三方库及pycharm中导入第三方库的问题
2020/03/10 Python
详解Python3中的 input() 函数
2020/03/18 Python
scrapy-splash简单使用详解
2021/02/21 Python
详解纯CSS3制作的20种loading动效
2017/07/05 HTML / CSS
.NET是怎么支持多种语言的
2015/02/24 面试题
顺丰快递Java软件工程师面试题
2015/07/31 面试题
教师节学生演讲稿
2014/09/03 职场文书
实习证明格式范文
2014/10/14 职场文书
vue3.0 数字翻牌组件的使用方法详解
2022/04/20 Vue.js
USB TYPE-C 或将成为所有智能手机充电标准
2022/04/21 数码科技
MySQL的意向共享锁、意向排它锁和死锁
2022/07/15 MySQL
分享很少见很有用的SQL功能CORRESPONDING
2022/08/05 MySQL