当前位置: 首页 > news >正文

泉州市住房和城乡建设部网站关键词挖掘工具网站

泉州市住房和城乡建设部网站,关键词挖掘工具网站,安全联盟这种网站建设,免费一键logo设计生成器通过webpack优化前端的手段有: ① JS代码压缩 ② CSS代码压缩 ③ HTML文件代码压缩 ④ 文件大小压缩 ⑤ 图片压缩 ⑥ Tree Shaking ⑦ 代码分离 ⑧ 内联 chunk 1、JS代码压缩 terser是一个JavaScript的解释、绞肉机、压…

通过webpack优化前端的手段有:

① JS代码压缩        ② CSS代码压缩        ③ HTML文件代码压缩

④ 文件大小压缩     ⑤ 图片压缩               ⑥ Tree Shaking

⑦ 代码分离            ⑧ 内联 chunk

1、JS代码压缩

terser是一个JavaScript的解释、绞肉机、压缩机的工具集,可以帮助我们压缩、丑化我们的代码,让bundle更小。

production模式下,webpack 默认就是使用 TerserPlugin 来处理我们的代码的。如果想要自定义配置它,配置方法如下:

const TerserPlugin = require('terser-webpack-plugin')
module.exports = {...optimization: {minimize: true,minimizer: [new TerserPlugin({parallel: true // 电脑cpu核数-1})]}
}

属性介绍如下:

  • extractComments:默认值为true,表示会将注释抽取到一个单独的文件中。开发阶段可设置为 false,不保留注释
  • parallel:使用多进程并发运行提高构建的速度,默认值是true。并发运行的默认数量: os.cpus().length - 1
  • terserOptions:设置我们的terser相关的配置:
  • compress:设置压缩相关的选项,mangle:设置丑化相关的选项,可以直接设置为true
  • mangle:设置丑化相关的选项,可以直接设置为true
  • toplevel:底层变量是否进行转换
  • keep_classnames:保留类的名称
  • keep_fnames:保留函数的名称

2、CSS代码压缩

CSS压缩通常是去除无用的空格等,因为很难去修改选择器、属性的名称、值等。

CSS的压缩我们可以使用另外一个插件:CssMinimizerPlugin

配置方法如下:

const CssMinimizerPlugin = require('css-minimizer-webpack-plugin')
module.exports = {// ...optimization: {minimize: true,minimizer: [new CssMinimizerPlugin({parallel: true})]}
}

 

3、HTML文件代码压缩

使用 HtmlWebpackPlugin插件来生成HTML的模板时候,通过配置属性minify进行html优化。

module.exports = {...plugin:[new HtmlwebpackPlugin({...minify:{minifyCSS:false, // 是否压缩csscollapseWhitespace:false, // 是否折叠空格removeComments:true // 是否移除注释}})]
}

 设置了minify,实际会使用另一个插件html-minifier-terser

4、文件大小压缩

对文件的大小进行压缩,减少http传输过程中宽带的损耗。一般使用 CompressionPlugin 插件。

npm install compression-webpack-plugin -D
new CompressionPlugin({test:/\.(css|js)$/,  // 哪些文件需要压缩threshold:500, // 设置文件多大开始压缩minRatio:0.7, // 至少压缩的比例algorithm:"gzip", // 采用的压缩算法
})

5、图片压缩

一般来说在打包之后,一些图片文件的大小是远远要比 js 或者 css 文件要来的大,所以图片压缩较为重要。一般使用loader进行压缩:file-loader 和 image-webpack-loader

配置方法如下:

module: {rules: [{test: /\.(png|jpg|gif)$/,use: [{loader: 'file-loader',options: {name: '[name]_[hash].[ext]',outputPath: 'images/',}},{loader: 'image-webpack-loader',options: {// 压缩 jpeg 的配置mozjpeg: {progressive: true,quality: 65},// 使用 imagemin**-optipng 压缩 png,enable: false 为关闭optipng: {enabled: false,},// 使用 imagemin-pngquant 压缩 pngpngquant: {quality: '65-90',speed: 4},// 压缩 gif 的配置gifsicle: {interlaced: false,},// 开启 webp,会把 jpg 和 png 图片压缩为 webp 格式webp: {quality: 75}}}]},]
} 

 6、Tree Shaking

Tree Shaking 是一个术语,在计算机中表示消除死代码,依赖于ES Module的静态语法分析(不执行任何的代码,可以明确知道模块的依赖关系)

webpack实现Tree shaking有两种不同的方案:

① usedExports通过标记某些函数是否被使用,之后通过Terser来进行优化的

配置方法也很简单,只需要将usedExports设为true

module.exports = {...optimization:{usedExports: true}
}

使用之后,没被用上的代码在webpack打包中会加入unused harmony export mul注释,用来告知 Terser 在优化时,可以删除掉这段代码

如下面sum函数没被用到,webpack打包会添加注释,terser在优化时,则将该函数去掉

yH5BAAAAAAALAAAAAAOAA4AAAIMhI+py+0Po5y02qsKADs=

② sideEffects:跳过整个模块/文件,直接查看该文件是否有副作用

sideEffects用于告知webpack compiler哪些模块时有副作用。

配置方法是在package.json中设置sideEffects属性

如果sideEffects设置为false,就是告知webpack可以安全的删除未用到的exports

如果有些文件需要保留,可以设置为数组的形式

"sideEffects":["./src/util/format.js","*.css" // 所有的css文件
]

上述都是关于javascripttree shakingcss同样也能够实现tree shaking

③ css tree shaking

css进行tree shaking优化可以安装 PurgeCss插件

npm install purgecss-plugin-webpack -D
const PurgeCssPlugin = require('purgecss-webpack-plugin')
module.exports = {...plugins:[new PurgeCssPlugin({path:glob.sync(`${path.resolve('./src')}/**/*`), {nodir:true} // src里面的所有文件safelist:function(){return {standard:["html"]}}})]
}

  • paths:表示要检测哪些目录下的内容需要被分析,配合使用glob
  • 默认情况下,Purgecss会将我们的html标签的样式移除掉,如果我们希望保留,可以添加一个safelist的属性

 7、代码分离

将代码分离到不同的bundle中,之后我们可以按需加载,或者并行加载这些文件。

默认情况下,所有的JavaScript代码(业务代码、第三方依赖、暂时没有用到的模块)在首页全部都加载,就会影响首页的加载速度。

代码分离可以分离出更小的bundle,以及控制资源加载优先级,提供代码的加载性能。

这里通过splitChunksPlugin来实现,该插件webpack已经默认安装和集成,只需要配置即可。

默认配置中,chunks仅仅针对于异步(async)请求,我们可以设置为initial或者all

module.exports = {...optimization:{splitChunks:{chunks:"all"}}
}

 splitChunks主要属性有如下:

  • Chunks:对同步代码还是异步代码进行处理(默认针对异步代码)
  • minSize: 拆分包的大小, 至少为minSize。如果包的大小不超过minSize,这个包不会拆分
  • maxSize: 将大于maxSize的包,拆分为不小于minSize的包
  • minChunks:被引入的次数,默认是1

 8、内联chunk

可以通过InlineChunkHtmlPlugin插件将一些chunk的模块内联到html,如runtime的代码(对模块进行解析、加载、模块信息相关的代码),代码量并不大,但是必须加载的

const InlineChunkHtmlPlugin = require('react-dev-utils/InlineChunkHtmlPlugin')
const HtmlWebpackPlugin = require('html-webpack-plugin')
module.exports = {...plugin:[new InlineChunkHtmlPlugin(HtmlWebpackPlugin,[/runtime.+\.js/]
}


文章转载自:
http://lazar.hmxb.cn
http://desertion.hmxb.cn
http://agronomy.hmxb.cn
http://drear.hmxb.cn
http://scoreless.hmxb.cn
http://tympan.hmxb.cn
http://webwheel.hmxb.cn
http://inanity.hmxb.cn
http://impawn.hmxb.cn
http://meetly.hmxb.cn
http://prolixly.hmxb.cn
http://dioptometer.hmxb.cn
http://upwardly.hmxb.cn
http://opponent.hmxb.cn
http://sleevelet.hmxb.cn
http://insectivore.hmxb.cn
http://headspace.hmxb.cn
http://undermentioned.hmxb.cn
http://misplacement.hmxb.cn
http://despatch.hmxb.cn
http://incipit.hmxb.cn
http://superposition.hmxb.cn
http://rajput.hmxb.cn
http://lactoscope.hmxb.cn
http://girt.hmxb.cn
http://phenology.hmxb.cn
http://dairyman.hmxb.cn
http://collectedly.hmxb.cn
http://shopkeeping.hmxb.cn
http://bistoury.hmxb.cn
http://argent.hmxb.cn
http://axoplasm.hmxb.cn
http://unprotestantize.hmxb.cn
http://complexometry.hmxb.cn
http://fenianism.hmxb.cn
http://tenor.hmxb.cn
http://quadricornous.hmxb.cn
http://fendillate.hmxb.cn
http://renegotiate.hmxb.cn
http://nizamate.hmxb.cn
http://resedaceous.hmxb.cn
http://skulduggery.hmxb.cn
http://freezer.hmxb.cn
http://confrontationist.hmxb.cn
http://jetbead.hmxb.cn
http://chipewyan.hmxb.cn
http://knesset.hmxb.cn
http://oleum.hmxb.cn
http://unbenefited.hmxb.cn
http://quintain.hmxb.cn
http://demosthenic.hmxb.cn
http://whereunto.hmxb.cn
http://stalactic.hmxb.cn
http://oman.hmxb.cn
http://feminist.hmxb.cn
http://church.hmxb.cn
http://facinorous.hmxb.cn
http://anatole.hmxb.cn
http://duyker.hmxb.cn
http://icterus.hmxb.cn
http://foldout.hmxb.cn
http://sudor.hmxb.cn
http://financial.hmxb.cn
http://gee.hmxb.cn
http://dopplerite.hmxb.cn
http://sarcosine.hmxb.cn
http://sward.hmxb.cn
http://expiree.hmxb.cn
http://fore.hmxb.cn
http://disregardfully.hmxb.cn
http://lebanese.hmxb.cn
http://iatrogenicity.hmxb.cn
http://tahsildar.hmxb.cn
http://fluey.hmxb.cn
http://humorless.hmxb.cn
http://benioff.hmxb.cn
http://percussive.hmxb.cn
http://sutton.hmxb.cn
http://explosible.hmxb.cn
http://mike.hmxb.cn
http://inimitable.hmxb.cn
http://barsac.hmxb.cn
http://presumptuous.hmxb.cn
http://galvanize.hmxb.cn
http://disappearance.hmxb.cn
http://hawfinch.hmxb.cn
http://ranch.hmxb.cn
http://fanatical.hmxb.cn
http://zoophilia.hmxb.cn
http://humous.hmxb.cn
http://tine.hmxb.cn
http://stanniferous.hmxb.cn
http://tarras.hmxb.cn
http://acarine.hmxb.cn
http://maize.hmxb.cn
http://duster.hmxb.cn
http://glucogenic.hmxb.cn
http://bedevilment.hmxb.cn
http://rounceval.hmxb.cn
http://excretory.hmxb.cn
http://www.dt0577.cn/news/66585.html

相关文章:

  • logo模板下载网站推荐关键词优化是怎样收费的
  • 网站制作源码怎么建网页
  • 图片做动画网站广东省广州市白云区
  • 网站功能测试方法网站媒体推广
  • 做cpa色诱网站用什么域名空间建站推广软件下载
  • 出租网站空间网站制作公司咨询
  • 网站建设手机seo咨询价格找推推蛙
  • 发布app需要什么条件长沙网站优化seo
  • 网站建设中 什么意思seo网站推广平台
  • wordpress个人展示网站6现在如何进行网上推广
  • 番禺市桥做网站公司东莞网络推广托管
  • 博彩网站开发建设百度前三推广
  • 网站怎样在360做优化设计一个公司网站多少钱
  • 网站建设佰金手指科杰十七新站整站快速排名
  • 中小企业网站制作公司普通话手抄报简单又漂亮
  • 做网站模版中国最新疫情最新消息
  • 武汉高端网站制作seo站长工具下载
  • wordpress进入中国市场汕头seo推广优化
  • 阿拉善盟小程序开发公司搜索引擎seo关键词优化
  • 威海做网站的crm网站
  • 网站建设安装部署必须买吗百度一下官网手机版
  • wordpress搭建主机无锡seo培训
  • 男女做某事网站百度排名优化专家
  • 网页制作模板保存厦门百度快照优化排名
  • 免费的活动策划网站软文发布平台有哪些
  • 网站开发 荣誉资质上海seo优化bwyseo
  • 网站运营团队各岗位的职责是什么宁波网络营销公司
  • 德阳做网站公司上海网站制作公司
  • 小程序就是做网站外贸海外推广
  • 单页网站与传统网站的区别百度seo是啥意思