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 相关文章推荐
jQuery EasyUI API 中文文档 - Menu菜单
Oct 03 Javascript
JavaScript输入邮箱自动提示实例代码
Jan 13 Javascript
JavaScript阻止事件冒泡示例分享
Dec 28 Javascript
javascript实现十秒钟后注册按钮可点击的方法
May 13 Javascript
JS实现兼容性好,带缓冲的动感网页右键菜单效果
Sep 18 Javascript
JS中JSON对象和String之间的互转及处理技巧
Apr 06 Javascript
JS实现简单拖拽效果
Jun 21 Javascript
浅谈vue项目如何打包扔向服务器
May 08 Javascript
详解js实时获取并显示当前时间的方法
May 10 Javascript
150行代码带你实现微信小程序中的数据侦听
May 17 Javascript
vue组件暴露和.js文件暴露接口操作
Aug 11 Javascript
MutationObserver在页面水印实现起到的作用详解
Jul 07 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版(2)
2006/10/09 PHP
防止本地用户用fsockopen DDOS攻击对策
2011/11/02 PHP
PHP图片自动裁切应付不同尺寸的显示
2014/10/16 PHP
php使用post数组的键值创建同名变量并赋值的方法
2015/04/03 PHP
PHP实现冒泡排序的简单实例
2016/05/26 PHP
form表单action提交的js部分与html部分
2014/01/07 Javascript
JS判断字符串包含的方法
2015/05/05 Javascript
jquery点击切换背景色的简单实例
2016/08/25 Javascript
利用Node.js制作爬取大众点评的爬虫
2016/09/22 Javascript
详解JavaScript权威指南之对象
2016/09/27 Javascript
Vue.js实现移动端短信验证码功能
2017/03/29 Javascript
vuejs+element-ui+laravel5.4上传文件的示例代码
2017/08/12 Javascript
利用express启动一个server服务的方法
2017/09/17 Javascript
jquery的 filter()方法使用教程
2018/03/22 jQuery
基于vue cli 通过命令行传参实现多环境配置
2018/07/12 Javascript
vue过滤器用法实例分析
2019/03/15 Javascript
jQuery实现消息弹出框效果
2019/12/10 jQuery
详解JavaScript中的链式调用
2020/11/27 Javascript
elementui实现预览图片组件二次封装
2020/12/29 Javascript
举例讲解Python设计模式编程中对抽象工厂模式的运用
2016/03/02 Python
Python实现的弹球小游戏示例
2017/08/01 Python
VScode编写第一个Python程序HelloWorld步骤
2018/04/06 Python
PyQt5每天必学之进度条效果
2018/04/19 Python
python实现趣味图片字符化
2019/04/30 Python
基于css3 animate制作绚丽的动画效果
2015/11/24 HTML / CSS
世界上最悠久的自行车制造商:Ribble Cycles
2017/03/18 全球购物
BudgetAir印度:预订航班、酒店和汽车租赁
2019/07/07 全球购物
物流管理毕业生自荐信
2013/10/24 职场文书
2014领导干部四风问题查摆思想汇报
2014/09/13 职场文书
房产公证书格式
2015/01/26 职场文书
大学生个人总结范文
2015/02/15 职场文书
会计求职信怎么写
2015/03/20 职场文书
公司仓库管理制度
2015/08/04 职场文书
建筑工程挂靠协议书
2016/03/23 职场文书
JavaScript canvas实现流星特效
2021/05/20 Javascript
使用 MybatisPlus 连接 SqlServer 数据库解决 OFFSET 分页问题
2022/04/22 SQL Server