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

网站建设制作设计推广优化近期的新闻热点

网站建设制作设计推广优化,近期的新闻热点,中文个人网站欣赏,吉利的广告公司名字1.背景描述 使用mini-css-extract-plugin插件来打包css文件(从css文件中提取css代码到单独的文件中,对css代码进行代码压缩等)。 本次采用三个配置文件: 公共配置文件:webpack.common.jsdev开发环境配置文件&#x…

1.背景描述

使用mini-css-extract-plugin插件来打包css文件(从css文件中提取css代码到单独的文件中,对css代码进行代码压缩等)。

本次采用三个配置文件:

  • 公共配置文件:webpack.common.js
  • dev开发环境配置文件:webpack.dev.js
  • prod生产环境配置文件:webpack.prod.js

2.webpack.common.js (公共配置文件)

  • 开发环境和生产环境共用的配置,借助webpack-merge插件,可以merge到开发或生产环境,从而减少重复配置。
  • 引入了Node环境变量process.env.NODE_ENV,可以根据传入的环境参数,动态更改配置,具体请看代码。
npm i -D mini-css-extract-plugin webpack-merge html-webpack-plugin
const HtmlWebpackPlugin = require("html-webpack-plugin");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const devMode = process.env.NODE_ENV != "production"
const path = require('path');module.exports = {entry: './src/index.js',devServer: {static: '/dist'},module: {rules: [{test: /\.(sa|sc|c)ss$/,  // 可以打包后缀为sass/scss/css的文件use: [{loader: MiniCssExtractPlugin.loader,options: {// 指定一个 publicPath,默认使用 webpackOptions.output中的publicPath// publicPath的配置,和plugins中设置的filename和chunkFilename的名字有关// 如果打包后,background属性中的图片显示不出来,请检查publicPath的配置是否有误// publicPath: './src',publicPath: devMode ? './src' : './src',   // 根据不同环境指定不同的publicPath},},'css-loader',// 'sass-loader'],},]},plugins: [// 创建了一个全新的html文件,所有的 bundle 都自动添加到其中。new HtmlWebpackPlugin({title: 'development'}),// css代码分离new MiniCssExtractPlugin({// 这里的配置和webpackOptions.output中的配置相似// 即可以通过在名字前加路径,来决定打包后的文件存在的路径filename: devMode ? 'css/[name].css' : 'css/[name].[hash].css',chunkFilename: devMode ? 'css/[id].css' : 'css/[id].[hash].css',})],output: {filename: '[name].bundle.js',path: path.resolve(__dirname, 'dist'),// 每次构建前清理 /dist 文件夹clean: true,},optimization: {// 进行代码分离splitChunks: {chunks: 'all',},}
}

3.webpack.dev.js(dev环境的配置文件)

  • dev环境的配置,记得把mode设置为development模式,否则webpack4以后会默认为production模式。
npm i -D webpack-merge

注意引入merge是使用 { merge } 形式:

const { merge } = require("webpack-merge");
const common = require("./webpack.common");module.exports = merge(common, {// dev环境的配置,记得把mode设置为development模式,否则webpack会默认为production模式。mode: "development",// 可以将编译后的代码映射回原始源代码,便于追踪 error 和 warning(浏览器中打开生成的 index.html 文件,点击按钮后控制台将会报错)devtool: 'inline-source-map',
});

4.webpack.prod.js(生产环境的配置文件)

  • 生产环境的配置,默认开启tree-shaking和js代码压缩;
  • 通过optimize-css-assets-webpack-plugin插件可以对css进行压缩,与此同时,必须指定js压缩插件(例子中使用terser-webpack-plugin插件),否则webpack不再对js文件进行压缩;(webpack5中不再支持optimize-css-assets-webpack-plugin插件而是使用css-minimizer-webpack-plugin)
  • 设置optimization.splitChunks.cacheGroups,可以将css代码块提取到单独的文件中。
  • 注意生产环境必须使用devTool:'source-map',否则报警告页面渲染不出来
const { merge } = require("webpack-merge");
const common = require("./webpack.common");
// 生成环境下对JS进行压缩
const TerserJSPlugin = require('terser-webpack-plugin');
// 生成环境下对CSS进行压缩
const CssMinimizerWebpackPlugin = require("css-minimizer-webpack-plugin");module.exports = merge(common, {// dev环境的配置,记得把mode设置为development模式,否则webpack会默认为production模式。mode: "production",devtool: 'source-map',optimization: {minimizer: [new TerserJSPlugin({}), new CssMinimizerWebpackPlugin({})],splitChunks: {cacheGroups: {styles: {name: 'styles',test: /\.css$/,chunks: 'all',enforce: true,},}},}
});

和dev环境同样的配置会报以下警告,页面也渲染不出来:

使用css-minimizer-webpack-plugin和terser-webpack-plugin插件也无法正常启动

解决:

是因为使用了devtool:"inline-source-map"选项配置后报警告,改为devtool:"source-map"后启动正常

5.package.json配置文件

  • sideEffects: 生产环境打包的时候,会默认开启tree-shaking,如果不设置sideEffects,某些通过import方式引入的css文件可能不会被打包,因为tree-shaking会甩掉没有导出任何东西(即文件中没有export关键字)的文件。所以,不希望被tree-shaking的文件,请在sideEffects中配置与之匹配的正则表达式(如下,在package.json中添加)。
  • NODE_ENV: 由于项目中用到了Node的环境变量,所以打包时需通过NODE_ENV传入环境变量。例如:"script":{ "dev": "set NODE_ENV=development && webpack serve --open --config ./webpack.dev.js --mode=development"})。
{"sideEffects": ["*.css","*.scss","*.sass"],"scripts": {"dev": "set NODE_ENV=development && webpack serve --open --config ./webpack.dev.js --mode=development","prod": "set NODE_ENV=production && webpack serve --open --config ./webpack.prod.js --mode=production"},
}

6.总结:

  • 不同环境下的打包,如果出现图片显示不了时(特别是css中的图片),请检查publicPath的配置。
  • mode: 'production'会开启tree-shaking和js代码压缩,但配置optimization. minimizer会使默认的压缩功能失效。所以,指定css压缩插件的同时,务必指定js的压缩插件。
  • mini-css-extract-plugin插件,结合optimization.splitChunks.cacheGroups配置,可以把css代码打包到单独的css文件,且可以设置存放路径(通过设置插件的filenamechunkFilename)。
  • 生产环境下不能使用devtool:"inline-source-map",而用devtool:"source-map"

参考:mini-css-extract-plugin插件快速入门_mn_front的博客-CSDN博客

http://www.ds6.com.cn/news/73555.html

相关文章:

  • 现在还有人做网站吗网站策划报告
  • 域名备案网站建设方案书网站seo优化心得
  • 台州公司网站建设自己开一个培训机构流程
  • 微服务开发平台南宁seo推广公司
  • 免费做网站百度保障中心人工电话
  • app开发的价格安卓手机优化
  • 企业网站样式搜索引擎排名2020
  • 网站设计公司网站青岛百度代理公司
  • 做自媒体挣钱的网站有哪些小程序制作流程
  • WordPress未声明图片大小seo托管
  • 玉溪的网站建设公司seo外链优化方法
  • 外包做网站软文营销怎么写
  • 自己做企业网站的步骤引流人脉推广软件
  • 网站开发工具的功能百度seo关键词排名优化工具
  • 做一个网站能卖多少钱整合营销方案怎么写
  • 为何要屏蔽网站快照搜索引擎排名大全
  • 官网的建站过程1000个关键词
  • 好的网站建设公司排名怎样在百度上做免费推广
  • 设计网站公司湖南岚鸿设计网络营销做得好的企业有哪些
  • 西安市做网站的公司自动外链
  • 织梦做的网站怎么样网页制作学习
  • 网站系统的建设与管理网站制作的费用
  • 济南网站开发定制域名ip查询入口
  • 渭南做网站价格滨州seo排名
  • 1688网站一起做网店网站设计制作在哪能看
  • 新手做网站服务器用什么成都企业网站seo技术
  • 用户要承担暖气费的税吗seo的概念是什么
  • 企业信息年报系统seo推广公司有哪些
  • 泉做网站的公司潍坊seo建站
  • 公众号制作培训苏州百度快照优化排名