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

沈阳三好街做网站公司做网页局域网站点配置

沈阳三好街做网站公司,做网页局域网站点配置,手机网站快速建站,自己做的网站算广告吗01 构建配置抽离成npm包; 意义:通用性: 业务开发者无需关注构建配置 统一团队构建脚本可维护性:构建配置合理的拆分 质量:冒烟测试 单元测试 持续集成构建配置管理的可选方案:1 通过多个配置文件管理不同…

01 构建配置抽离成npm包;

意义:通用性: 业务开发者无需关注构建配置 统一团队构建脚本可维护性:构建配置合理的拆分 质量:冒烟测试  单元测试 持续集成构建配置管理的可选方案:1 通过多个配置文件管理不同环境的构建:在package.json文件中进行配置。 项目中默认配置文件,webpack.config.js, 可以设置开发环境的文件 webpack.dev.js 生产环境 webpack.pro.jswebpack --config webpack.dev.js  开发环境webpack --config webpack.pro.js  生成环境2 将构建配置设计成一个库 比如 hjs-webpack  Neutrino webpack-blocks等3 抽成一个工具进行管理 比如 create-react-app

02 构建配置包设计

通过多个配置文件管理不同环境的webpakc配置基础配置 webpack.base.js开发环境 webpack.dev.js生产环境 webpack.pro.jsSSR环境 webpack.ssr.js抽离成一个npm包统一管理规范:Git commit日志 README ESLint Semver质量 冒烟测试 单元测试 测试覆盖率和CI

03 通过webpack-merge合并配置

const merge = require('webpack-merge')module.exports = merge(baseConfig,devConfig)合并规则如下:merge({a:[1],b:5,c:23},{a:[2],b:6,c:40,d:60}){a:[1,2],b:6,c:40,d:60}

04 目录结构的设计

05 各文件之间的功能

06 构建统计信息,可以查看各个文件打包后的大小

package.json中使用stats"scripts":{"build:stats":"webpack --env production --json > stats.json"}

07 webpack打包的速度分析,分析每个loader和插件打包的速度。

第一步 进行插件的安装:npm install --save-dev speed-measure-webpack-plugin 第二步 插件的导入  const SpeedMeasureWebpackPlugin = require('speed-measure-webpack-plugin ')第三步 创建插件的对象const smp = new SpeedMeasureWebpackPlugin()第四步 将要导出的配置进行包裹module.exports = smp.wrap({entry:'',output:'',mode:'',...})

08 webpack打包后分析体积:需要借助webpack-bundle-analyzer;

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPluginmodule.exports = {Plugins:[new BundleAnalyzerPlugin()]}项目在8888端口可以使用可视化的图标查看打包后的体积

09 多进程/多实例:使用thread-loader解析资源,加快打包的速度。

原理:每次webpack解析一个模块,thread-loader会将它及它的依赖分配给worker线程中module.exports = {module:{rules:[{test:/.js$/,use:[{loader:'thread-loader',options:{workers:3}},'babel-loader']}]   }}

10 多进程/多实例 并行压缩代码:使用terser-webpack-plugin开启parallel参数;

const TerserPlugin = require('terser-webpack-plugin')module.exports = {optimization:{minimizer:[new TerserPlugin({parallel:true})]}}

11 webpack设置分包:预编译资源模块:

思路:将react react-dom redux  react-redux 基础包和业务基础包打包成一个文件方法:使用DLLPlugin 进行分包, DllReferencePlugin对manifest.json引用第一步 项目根目录下创建一个webpack.dll.js文件const path = require('path')const webpack = require('webpack')module.exports = {entry:{library:['react','redux','react-redux','react-dom']
},output:{filename:'[name]_[chunkhash].dll.js',path:path.join(__dirname,'build/library'),library:'[name]'
},plugins:[new webpack.DllPlugin({name:'[name]_[hash]',path: path.join(__dirname,'build/library/[name].json')})
]}第二步 package.json文件中"scripts":{"dll":"webpack --config webpack.dll.js"}第三步 执行  npm run dll :将会在build / library目录下打包出一个library_xxxx.js的文件第四步 在webpack.config.js文件中引入打包后的文件module.exports = {plugins:[new webpack.DllReferencePlugin({manifest:require('./build/library/library_xxx.json')})]}

12 利用缓存提升二次构建的速度

缓存思路:1  babel-laoder 开启缓存2  terser-webpack-plugin 开启缓存module.exports = {optimization:{minimizer:[new TerserPlugin({parallel:true,cache:true})]}}3  使用cache-loader 或者 hard-source-webpack-pluginconst HardSoirceWebpackPlugin = require('hard-source-webpack-plugin')module.exports = {plugins:[new HardSoirceWebpackPlugin()]}

13 缩小构建目标,减少文件搜索范围

优化 resolve.modules配置 减少模块搜索层级优化 resolve.mainFields 配置优化 resolve.extensions 配置 合理使用 aliasmodule.exports = {resolve:{alias:{// 遇到react直接查找 这个目录下的就可以了react:path.resolve(__dirname,'./node_module/react/dist/react.main.js'),},modules:[path.resolve(__dirname,'node_modules')], 查找依赖的路径extensions:['.js'],mainFields:['main']}}

14 打包排除没有使用到的css样式

需要purgecss-webpack-plugin结合mini-css-extract-plugin使用webpack.config.js文件中const PurgecssWebpackPlugin = require('purgecss-webpack-plugin')const MiniCssExtractPlugin = require('mini-css-extract-plugin')const PATHS = {src:path.join(__dirname.'src')}module.exports = {plugins:[new PurgecssWebpackPlugin({paths:glob.sync(`${PATHS.src}/**/*`,{nodir:true})})]}

15 webpack对图片进行压缩

rules: [{test:/.(giflpngljpe?glsvg)$/i,use:['file-loader',loader: 'image-webpack-loader',options:{mozjpeg:{progressive: true,quality: 65}// optipng.enabled: false will disable optipngoptipng:{enabled: false,}pngquant: {quality:'65-90',speed: 4}gifsicle: {interlaced: false,}// the webp option will enable WEBPwebp:{quality:75}}}
}

http://www.yayakq.cn/news/455000/

相关文章:

  • php与dw怎么做校园网站做网站源码需要多少钱
  • 泉州住房建设局网站注册城乡规划师
  • 达内网站建设wordpress连接sql
  • 上蔡专业网站建设高端网站建站
  • 批量网站访问检测php网站制作教程
  • 易加网站建设方案亚洲tv
  • 查询网站备案查询深圳宝安区网站建设
  • 葫芦岛建设工程信息网站开发一款app需要多少钱?
  • 黑龙省建设厅网站wordpress关闭功能
  • 网站制作 北京网站建设公司天晴创艺网站建设百度小程序
  • 俄语淘宝网站建设品牌建设的概念
  • 推销什么企业做网站和app6湖北好的快速排名系统
  • 厦门网站建设求职简历优质的杭州网站优化
  • 网站的首页标题在哪里设置的江苏省建设工人考勤网站
  • 北京住房投资建设中心网站首东莞阳光网官方网站登录
  • 网站源码如何使用wordpress文章怎么消失
  • 长沙wap网站建设办公室装修方案
  • 做英文网站地图四川中天建设有限公司网站
  • 兰州网站建设与优化推广wordpress 图片说明
  • 零陵网站建设wap网站在线生成app
  • 罗湖商城网站设计企业建站需要多少钱
  • 医院类网站建设与维护前端优化
  • 平台类网站做多久网站谁做的比较好看
  • 微站官网h5游戏大全在线玩
  • 爱站网反链查询怎样看一个网站是不是织梦做的
  • 如何优化基础建站免费服务器使用推荐
  • 网站建设找超速云网页与网站设计说明
  • 帮企业建设网站销售app开发技术有哪些
  • 网站建设配置文件无法粘贴高端网站建设网站定制
  • 网站开发项目经验和教训阿里巴巴国际站跨境电商平台