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 相关文章推荐
ExtJS 入门
Oct 29 Javascript
js 如何实现对数据库的增删改查
Nov 23 Javascript
轻松理解JavaScript闭包
Mar 14 Javascript
微信小程序对接七牛云存储的方法
Jul 30 Javascript
Angular 实现输入框中显示文章标签的实例代码
Nov 07 Javascript
Javascript实现一朵从含苞到绽放的玫瑰
Mar 30 Javascript
vue滚动tab跟随切换效果
Jun 29 Javascript
Layui给switch添加响应事件的例子
Sep 03 Javascript
ES2020 新特性(种草)
Jan 12 Javascript
在vue中使用Base64转码的案例
Aug 07 Javascript
Vue+element-ui添加自定义右键菜单的方法示例
Dec 08 Vue.js
原生JS实现分页
Apr 19 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 echo, print, print_r, sprintf, var_dump, var_expor的使用区别
2013/06/20 PHP
js导航菜单(自写)简单大方
2013/03/28 Javascript
解析jquery获取父窗口的元素
2013/06/26 Javascript
jQuery.extend()的实现方式详解及实例
2013/06/29 Javascript
javascript简单实现命名空间效果
2014/03/06 Javascript
Jquery动态添加及删除页面节点元素示例代码
2014/06/16 Javascript
浅谈javascript的分号的使用
2015/05/12 Javascript
js带缩略图的图片轮播效果代码分享
2015/09/14 Javascript
javascript实现右侧弹出“分享到”窗口效果
2016/02/01 Javascript
JavaScript的React框架中的JSX语法学习入门教程
2016/03/05 Javascript
15款最好的Bootstrap在线编辑器
2016/08/03 Javascript
Vue-Cli中自定义过滤器的实现代码
2017/08/12 Javascript
vue 录制视频并压缩视频文件的方法
2018/07/27 Javascript
JavaScript笛卡尔积超简单实现算法示例
2018/07/30 Javascript
实例详解vue.js浅度监听和深度监听及watch用法
2018/08/16 Javascript
vue根据进入的路由进行原路返回的方法
2018/09/26 Javascript
JQuery常见节点操作实例分析
2019/05/15 jQuery
微信小程序 自定义弹窗实现过程(附代码)
2019/12/05 Javascript
vue 子组件修改data或调用操作
2020/08/07 Javascript
vue祖孙组件之间的数据传递案例
2020/12/07 Vue.js
[02:54]DOTA2亚洲邀请赛 VG战队出场宣传片
2015/02/07 DOTA
Python使用Scrapy爬虫框架全站爬取图片并保存本地的实现代码
2018/03/04 Python
在windows下Python打印彩色字体的方法
2018/05/15 Python
pandas.dataframe中根据条件获取元素所在的位置方法(索引)
2018/06/07 Python
Python实现绘制双柱状图并显示数值功能示例
2018/06/23 Python
Django 使用easy_thumbnails压缩上传的图片方法
2019/07/26 Python
详解mac python+selenium+Chrome 简单案例
2019/11/08 Python
Python3的socket使用方法详解
2020/02/18 Python
python3 deque 双向队列创建与使用方法分析
2020/03/24 Python
Django中template for如何使用方法
2021/01/31 Python
采购员的工作职责
2013/12/26 职场文书
大学生冰淇淋店商业计划书
2014/01/14 职场文书
创建市级文明单位实施方案
2014/03/01 职场文书
心理健康活动总结
2014/04/30 职场文书
市场营销专业应届生自荐信
2014/06/19 职场文书
CSS 新特性 contain控制页面的重绘与重排问题
2021/04/30 HTML / CSS