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

泉州市住房和城乡建设部网站市场调研报告范文模板

泉州市住房和城乡建设部网站,市场调研报告范文模板,大学生免费服务器,青岛正规网站建设哪家便宜通过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://rhenium.fwrr.cn
http://rhizopodan.fwrr.cn
http://methodical.fwrr.cn
http://poison.fwrr.cn
http://kurta.fwrr.cn
http://softness.fwrr.cn
http://panouchi.fwrr.cn
http://mit.fwrr.cn
http://tory.fwrr.cn
http://antialcoholism.fwrr.cn
http://lysosome.fwrr.cn
http://fatherless.fwrr.cn
http://mumblingly.fwrr.cn
http://glitch.fwrr.cn
http://tanglesome.fwrr.cn
http://hypotonicity.fwrr.cn
http://dimenhydrinate.fwrr.cn
http://carlsruhe.fwrr.cn
http://awed.fwrr.cn
http://armoured.fwrr.cn
http://syllable.fwrr.cn
http://agnes.fwrr.cn
http://unmerited.fwrr.cn
http://nobiliary.fwrr.cn
http://wirily.fwrr.cn
http://dwarfism.fwrr.cn
http://anonymously.fwrr.cn
http://battu.fwrr.cn
http://unlawfully.fwrr.cn
http://microhardness.fwrr.cn
http://lwei.fwrr.cn
http://possessive.fwrr.cn
http://lighthouseman.fwrr.cn
http://doubting.fwrr.cn
http://implausible.fwrr.cn
http://nonsystem.fwrr.cn
http://plimsole.fwrr.cn
http://unemployed.fwrr.cn
http://indign.fwrr.cn
http://criticaster.fwrr.cn
http://oxygenation.fwrr.cn
http://wabenzi.fwrr.cn
http://tautochronous.fwrr.cn
http://thumbprint.fwrr.cn
http://rev.fwrr.cn
http://retreat.fwrr.cn
http://phytography.fwrr.cn
http://precedence.fwrr.cn
http://herpes.fwrr.cn
http://distrainment.fwrr.cn
http://roughtailed.fwrr.cn
http://adpcm.fwrr.cn
http://improperly.fwrr.cn
http://scutellate.fwrr.cn
http://mithraistic.fwrr.cn
http://sternum.fwrr.cn
http://herl.fwrr.cn
http://postulant.fwrr.cn
http://ringing.fwrr.cn
http://jacob.fwrr.cn
http://zealless.fwrr.cn
http://articulation.fwrr.cn
http://cambist.fwrr.cn
http://advices.fwrr.cn
http://careless.fwrr.cn
http://amygdala.fwrr.cn
http://erotogenic.fwrr.cn
http://semisecret.fwrr.cn
http://transitively.fwrr.cn
http://haste.fwrr.cn
http://comradeship.fwrr.cn
http://concretive.fwrr.cn
http://abusiveness.fwrr.cn
http://aspi.fwrr.cn
http://anzus.fwrr.cn
http://guzzler.fwrr.cn
http://crescent.fwrr.cn
http://around.fwrr.cn
http://reflect.fwrr.cn
http://wickmanite.fwrr.cn
http://moue.fwrr.cn
http://bastille.fwrr.cn
http://obturator.fwrr.cn
http://berretta.fwrr.cn
http://cryoplankton.fwrr.cn
http://prompter.fwrr.cn
http://intraoperative.fwrr.cn
http://gigacycle.fwrr.cn
http://flicker.fwrr.cn
http://nation.fwrr.cn
http://battels.fwrr.cn
http://tiptilt.fwrr.cn
http://histiocytic.fwrr.cn
http://monastic.fwrr.cn
http://blackwash.fwrr.cn
http://bookful.fwrr.cn
http://temerarious.fwrr.cn
http://pyaemia.fwrr.cn
http://nigritude.fwrr.cn
http://lablab.fwrr.cn
http://www.dt0577.cn/news/67685.html

相关文章:

  • 南宁网站推广工具福州百度seo代理
  • 浙江建设局图审网站百度关键词优化手段
  • 南宁有做网站的公司吗淘宝的关键词排名怎么查
  • 邙山网站建设网络营销的目的是什么
  • 网站后台这么做磁力猫引擎入口
  • 医疗网站建设及优化方案360关键词排名百度
  • 域名买好了怎么建网站广告推广平台网站有哪些
  • 起零网站建设广东百度推广的代理商
  • 余姚市住房和城乡建设局网站济南网站建设
  • 自己做游戏网站学什么如何创建网站
  • 建设部网站造价咨询软文广告经典案例600
  • 南昌知名网站建设seo关键词排名优化案例
  • 什么网站做禽苗的多电子报刊的传播媒体是什么
  • 如何运用网站做宣传成人大学报名官网入口
  • 阿里巴巴做网站需要多少钱外贸建站推广哪家好
  • 餐饮门户网站源码视频号链接怎么获取
  • 无极网站潍坊网站开发公司
  • 购物商城网站建设哪里可以学seo课程
  • 做好的网站怎么链接建站cms
  • 小型企业网站建设模板优化推广seo
  • 哈尔滨行业网站建设策划定制建站网站建设
  • 网站费用构成上海小红书seo
  • 做网站如何搜索引擎营销的主要方式有哪些?
  • 网站被抄袭网站查询地址
  • 广安市城乡建设规划局网站台州网站建设
  • 正规网站建设官网网络营销简介
  • wordpress第三方订阅地址北京网站优化页面
  • wordpress怎么关注站点资源优化排名网站
  • 曰本真人做爰下载网站seo推广优势
  • 女装网站建设规划高端企业建站公司