SSR就是一台服务器,可以利用 SSR 在远程的服务器上配置 SSR,使其能够成为 SSR 节点,这样本地电脑或者其它设备利用 SSR 节点实现 VPN 或者远程上网及游戏加速等方面。ShadowsocksR(简称 SSR)是 Shadowsocks 分支,在 Shadowsocks 的基础上增加了一些数据...
一、Visual Studio Code下载地址:https://code.visualstudio.com/微软在2015年4月30日Build 开发者大会上正式宣布了 Visual Studio Code 项目:一个运行于 Mac OS X、Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器。Visual Stud...
0、写在前面
Webpack优化可以分为优化开发体验和优化输出质量两部分
1、优化开发体验
优化开发体验的目的是为了提升开发时的效率,其中又可以分为以下几点:
优化构建速度。在项目庞大时构建耗时可能会变的很长,每次等待构建的耗时加起来也会是个大数目。
4-1-1 在配置
Loader
时通过include
去缩小命中范围4-1-2 优化
resolve.modules
配置,指明存放第三方模块的绝对路径,以减少寻找,配置如下:4-1-3 优化
resolve.mainFields
配置4-1-4 优化
resolve.alias
配置4-1-5 优化
resolve.extensions
配置在配置
resolve.extensions
时你需要遵守以下几点,以做到尽可能的优化构建性能:4-1-6 优化
module.noParse
配置后缀尝试列表要尽可能的小,不要把项目中不可能存在的情况写到后缀尝试列表中。
频率出现最高的文件后缀要优先放在最前面,以做到尽快的退出寻找过程。
在源码中写导入语句时,要尽可能的带上后缀,从而可以避免寻找过程。例如在你确定的情况下把
require('./data')
写成require('./data.json')
。4-1 缩小文件搜索范围
4-2 使用 DllPlugin
为什么给 Web 项目构建接入 动态链接库 的思想后,会大大提升构建速度呢? 原因在于包含大量复用模块的动态链接库只需要编译一次,在之后的构建过程中被动态链接库包含的模块将不会在重新编译,而是直接使用动态链接库中的代码。 由于动态链接库中大多数包含的是常用的第三方模块,例如
react
、react-dom
,只要不升级这些模块的版本,动态链接库就不用重新编译。4-3 使用 HappyPack
在整个
Webpack
构建流程中,最耗时的流程可能就是Loader
对文件的转换操作了,因为要转换的文件数据巨多,而且这些转换操作都只能一个个挨着处理。(运行在 Node.js 之上的 Webpack 是单线程模型的)HappyPack的核心原理就是把这部分任务分解到多个进程去并行处理,从而减少了总的构建时间。
4-4 使用 ParallelUglifyPlugin
ParallelUglifyPlugin 会开启多个子进程,把对多个文件的压缩工作分配给多个子进程去完成,每个子进程其实还是通过
UglifyJS
去压缩代码,但是变成了并行执行。 所以ParallelUglifyPlugin
能更快的完成对多个文件的压缩工作。优化使用体验。通过自动化手段完成一些重复的工作,让我们专注于解决问题本身。
4-5 使用自动刷新
使用
webpack
模块负责监听文件,webpack-dev-server
模块则负责刷新浏览器。4-6 开启模块热替换
2、优化输出质量
优化输出质量的目的是为了给用户呈现体验更好的网页,例如减少首屏加载时间、提升性能流畅度等。 这至关重要,因为在互联网行业竞争日益激烈的今天,这可能关系到你的产品的生死。
优化输出质量本质是优化构建输出的要发布到线上的代码,分为以下几点:
减少用户能感知到的加载时间,也就是首屏加载时间。
4-7 区分环境
4-8 压缩代码
4-9 CDN 加速
4-10 使用 Tree Shaking
Tree Shaking
可以用来剔除JavaScript
中用不上的死代码(没用到的代码)。它依赖静态的 ES6 模块化语法,例如通过 import 和 export 导入导出。4-11 提取公共代码
4-12 按需加载
提升流畅度,也就是提升代码性能。
4-13 使用 Prepack
4-14 开启 Scope Hoisting
作者:One_Hund
链接:https://www.jianshu.com/p/4f58b179c626
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
1,优化原理
(1)webpack 的 resolve.modules 是用来配置模块库(即 node_modules)所在的位置。当 js 里出现 import 'vue' 这样不是相对、也不是绝对路径的写法时,它便会到 node_modules 目录下去找。
(2)在默认配置下,webpack 会采用向上递归搜索的方式去寻找。但通常项目目录里只有一个 node_modules,且是在项目根目录。为了减少搜索范围,我们可以直接写明 node_modules 的全路径。
2,操作步骤
(1)打开 build/webpack.base.conf.js 文件,添加如下配置:
module.exports = {
resolve: {
extensions: [
'.js'
,
'.vue'
,
'.json'
],
modules: [
resolve(
'src'
),
resolve('node_modules')
],
alias: {
'vue$'
:
'vue/dist/vue.esm.js'
,
'@'
: resolve(
'src'
),
}
},
白屏可能是排线断了、如果关机后再开能解决问题那就是软件问题 要分不同的情况 1.你的机子是在什么情况下才白屏的呢? A,开机后过几分钟. (那么要重新写软件了.到维修台或厂家修.) B,开机就白屏. (80%是排线坏了.一年以外的到维修台维修.) 2.你的机子白屏到什么程度? A,有时候白屏,有时候不白屏. (排线坏或软件问题两种可能.) B.开机后.把手机上翻盖晃一点,屏现,再晃回去又白屏了. (换排线.) C.自始至终都是白屏.(80%要换排线) D.开好机子后.不动它.一会儿就白屏了.(软件问题.重新写软件OK) 3.你的机子以前是否维修过? 是,则又要更换传送排线了. 否.(即没修过).那么机子从买来到现在用了多长时间了? 一年以内可能要返厂保修了.超过一年了,要么要升级.要么换排线. 白屏一般是由于短信的MCE问题、记忆体损坏、系统错误、MEDIA已关闭、安装或删除游戏后、运行游戏(CS、DOOM)等原因引起的。
优化Loader配置
Loader处理文件的转换操作是很耗时的,所以需要让尽可能少的文件被Loader处理
优化resolve.modules配置
resolve.modules
用于配置webpack去哪些目录下寻找第三方模块,默认是['node_modules']
,但是,它会先去当前目录的./node_modules
查找,没有的话再去../node_modules
最后到根目录;所以当安装的第三方模块都放在项目根目录时,就没有必要安默认的一层一层的查找,直接指明存放的绝对位置
优化resolve.extensions配置
在导入没带文件后缀的路径时,webpack会自动带上后缀去尝试询问文件是否存在,而
resolve.extensions
用于配置尝试后缀列表;默认为extensions:['js','json']
;及当遇到
require('./data')
时webpack会先尝试寻找data.js
,没有再去找data.json
;如果列表越长,或者正确的后缀越往后,尝试的次数就会越多;所以在配置时为提升构建优化需遵守:
因为项目中用的
jsx
较多,所以配置extensions: [".jsx",".js"],
频率出现高的文件后缀优先放在前面;
列表尽可能的小;
书写导入语句时,尽量写上后缀名
1、优化开发体验
优化开发体验的目的是为了提升开发时的效率,其中又可以分为以下几点:
优化构建速度。在项目庞大时构建耗时可能会变的很长,每次等待构建的耗时加起来也会是个大数目。
4-1-1 在配置
Loader
时通过include
去缩小命中范围4-1-2 优化
resolve.modules
配置,指明存放第三方模块的绝对路径,以减少寻找,配置如下:4-1-3 优化
resolve.mainFields
配置4-1-4 优化
resolve.alias
配置4-1-5 优化
resolve.extensions
配置在配置
resolve.extensions
时你需要遵守以下几点,以做到尽可能的优化构建性能:4-1-6 优化
module.noParse
配置后缀尝试列表要尽可能的小,不要把项目中不可能存在的情况写到后缀尝试列表中。
频率出现最高的文件后缀要优先放在最前面,以做到尽快的退出寻找过程。
在源码中写导入语句时,要尽可能的带上后缀,从而可以避免寻找过程。例如在你确定的情况下把
require('./data')
写成require('./data.json')
。4-1 缩小文件搜索范围
4-2 使用 DllPlugin
为什么给 Web 项目构建接入 动态链接库 的思想后,会大大提升构建速度呢? 原因在于包含大量复用模块的动态链接库只需要编译一次,在之后的构建过程中被动态链接库包含的模块将不会在重新编译,而是直接使用动态链接库中的代码。 由于动态链接库中大多数包含的是常用的第三方模块,例如
react
、react-dom
,只要不升级这些模块的版本,动态链接库就不用重新编译。4-3 使用 HappyPack
在整个
Webpack
构建流程中,最耗时的流程可能就是Loader
对文件的转换操作了,因为要转换的文件数据巨多,而且这些转换操作都只能一个个挨着处理。(运行在 Node.js 之上的 Webpack 是单线程模型的)HappyPack的核心原理就是把这部分任务分解到多个进程去并行处理,从而减少了总的构建时间。
4-4 使用 ParallelUglifyPlugin
ParallelUglifyPlugin 会开启多个子进程,把对多个文件的压缩工作分配给多个子进程去完成,每个子进程其实还是通过
UglifyJS
去压缩代码,但是变成了并行执行。 所以ParallelUglifyPlugin
能更快的完成对多个文件的压缩工作。优化使用体验。通过自动化手段完成一些重复的工作,让我们专注于解决问题本身。
4-5 使用自动刷新
使用
webpack
模块负责监听文件,webpack-dev-server
模块则负责刷新浏览器。4-6 开启模块热替换
2、优化输出质量
优化输出质量的目的是为了给用户呈现体验更好的网页,例如减少首屏加载时间、提升性能流畅度等。 这至关重要,因为在互联网行业竞争日益激烈的今天,这可能关系到你的产品的生死。
优化输出质量本质是优化构建输出的要发布到线上的代码,分为以下几点:
减少用户能感知到的加载时间,也就是首屏加载时间。
4-7 区分环境
4-8 压缩代码
4-9 CDN 加速
4-10 使用 Tree Shaking
Tree Shaking
可以用来剔除JavaScript
中用不上的死代码(没用到的代码)。它依赖静态的 ES6 模块化语法,例如通过 import 和 export 导入导出。4-11 提取公共代码
4-12 按需加载
提升流畅度,也就是提升代码性能。
4-13 使用 Prepack
4-14 开启 Scope Hoisting
1、优化Loader配置
Loader处理文件的转换操作是很耗时的,所以需要让尽可能少的文件被Loader处理
{
test: /\.js$/,
use: [
'babel-loader?cacheDirectory'
,
//开启转换结果缓存
],
include: path.resolve(__dirname,
'src'
),
//只对src目录中文件采用babel-loader
exclude: path.resolve(__dirname,
' ./node_modules'
),
//排除node_modules目录下的文件
},
2、优化resolve.modules配置
resolve.modules
用于配置webpack去哪些目录下寻找第三方模块,默认是['node_modules']
,但是,它会先去当前目录的./node_modules
查找,没有的话再去../node_modules
最后到根目录;所以当安装的第三方模块都放在项目根目录时,就没有必要安默认的一层一层的查找,直接指明存放的绝对位置
resolve: {
modules: [path.resolve(__dirname,
'node_modules'
)],
}
3、优化resolve.extensions配置
在导入没带文件后缀的路径时,webpack会自动带上后缀去尝试询问文件是否存在,而
resolve.extensions
用于配置尝试后缀列表;默认为extensions:['js','json']
;及当遇到
require('./data')
时webpack会先尝试寻找data.js
,没有再去找data.json
;如果列表越长,或者正确的后缀越往后,尝试的次数就会越多;所以在配置时为提升构建优化需遵守:
频率出现高的文件后缀优先放在前面;
列表尽可能的小;
书写导入语句时,尽量写上后缀名
因为项目中用的
jsx
较多,所以配置extensions: [".jsx",".js"],
基本配置后查看构建速度:
Time: 10654ms
;配置前为Time: 11593ms
相关问题推荐
相对前几年来说,要高上不少了,毕竟入行的人也是越来越多了,基础的工作对应想要参与的人群基数越来越大,但是对于高端人才的需求还是很多,人才还是相对稀缺性的。所以,想要学web或者其他技术也一样,别等,别观望。web前端就业方向特别多包括web前端开发...
相对定位和绝对定位是定位的两种表现形式,区别如下:一、主体不同1、相对定位:是设置为相对定位的元素框会偏移某个距离。2、绝对定位:absolute 脱离文档流,通过 top,bottom,left,right 定位。二、特点不同1、相对定位:在使用相对定位时,无论是否进行移...
抓包(packet capture)就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作,也用来检查网络安全。抓包也经常被用来进行数据截取等。抓包可以通过抓包工具来查看网络数据包内容。通过对抓获的数据包进行分析,可以得到有用的信息。目前流行的...
常用的前端框架有Bootstrap框架、React框架、Vue框架、Angular框架、Foundation框架等等
前端是目的就业前景非常不错的一个计算机技术,但是自学的话还是有一定难度的,网络上自学是碎片化的,同时互联网技术跟新换代快,自己的话比较吃力也学习不到最新的技术。
SSR就是一台服务器,可以利用 SSR 在远程的服务器上配置 SSR,使其能够成为 SSR 节点,这样本地电脑或者其它设备利用 SSR 节点实现 VPN 或者远程上网及游戏加速等方面。ShadowsocksR(简称 SSR)是 Shadowsocks 分支,在 Shadowsocks 的基础上增加了一些数据...
计算机培训方向比较多,建议找适合自己的方向选择培训编程类:JAVA、WEB、Python、C/C++、C#等测试类:软件测试运维类:云计算、网络安全设计类:UI设计、3D建模等
1、代码判断xAxis: {type: 'time',splitLine: {show: false},interval: 3600, // 设置x轴时间间隔axisLabel: {formatter: function(value, index) {return liangTools.unix2hm(value)}}},首先要把xAxis 显示类型设置成time,然后设置对应X轴......
HTML5 + CSS + JavaScript 开发 跨平台重用代码
采用rem单位自动响应,并提供独有栅格化系统快速定义宽高、边距节省css代码量,同时总结各大型移动端网页,提供一套ui颜色搭配规范,尺寸规范,字体规范等。
iView UI、ioni、SUI
jQTouch
如果只是普通的移动端用vue react 或者dva 如果是要编译成小程序什么的或者混生 就用uni-app(对应vue语法)taro(对应react) 或者纯原生 这个没有限制的,自己怎么舒服怎么来
因为可以运用在网页和小程序的开饭中,而且开源,用着便宜,企业都很喜欢
一、Visual Studio Code下载地址:https://code.visualstudio.com/微软在2015年4月30日Build 开发者大会上正式宣布了 Visual Studio Code 项目:一个运行于 Mac OS X、Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器。Visual Stud...
jQuery自带淡入淡出效果 https://www.w3school.com.cn/jquery/jquery_fade.asp 看看这个