webpack -- 入门
来源:互联网 发布:淘宝服装拍摄报价 编辑:程序博客网 时间:2024/06/02 03:28
本文根据《入门Webpack,看这篇就够了》实践所写
webpack使用前准备
1、npm init 在文件根目录创建一个pageage.json文件,它是npm说明文件,包括当前项目的依赖模块,自定义的脚本任务等等
输入这个命令后,终端会问你一系列诸如项目名称,项目描述,作者等信息,package name 一定不能是webpack,其他不重要可以一直按回车,
2、安装Webpack
npm install –save-dev webpack 项目中安装
npm install -g webpack 全局中安装
- 3、建立两个文件夹
- app
Greeter.js
- main.js
- public
index.html
webpack使用
经过测试,webpack必须要安装在全局才可以使用
在终端直接使用: webpack app/main.js public/bundle.js
通过配置文件使用: webpack
//webpack.config.jsmodule.exports = { entry: __dirname + "/app/main.js",//已多次提及的唯一入口文件 output: { path: __dirname + "/public",//打包后的文件存放的地方 filename: "bundle.js"//打包后输出文件的文件名 }}
使用webpack构建本地服务器,自动刷新显示修改后的结果
安装组件
npm install --save-dev webpack-dev-server
配置
//webpack.config.jsdevServer: { contentBase: "./public",//本地服务器所加载的页面所在的目录 historyApiFallback: true,//不跳转 inline: true//实时刷新}
//package.json"scripts": { "test": "echo \"Error: no test specified\" && exit 1", "start": "webpack", "server": "webpack-dev-server --open"}
使用
npm run server 在8080端口查看
Loader
安装需要的loader组件
npm install --save-dev css-loader
配置
//webpack.config.jsmodule: { loaders: [ { test: /\.css$/, use:[//同一文件引入多个loader必须要分开写 { loader: "style-loader" }, { loader:"css-loader" }, { loader: "postcss-loader", options: { // 如果没有options这个选项将会报错 No PostCSS Config found plugins: (loader) => [ require('autoprefixer')(), //CSS浏览器兼容 ] } } ] }, ]}
PostCSS
使用PostCSS来为CSS代码自动添加适应不同浏览器的CSS前缀
安装
//安装postcss-loader 和 autoprefixer(自动添加前缀的插件)npm install --save-dev postcss-loader autoprefixer
配置
module: { loaders: [ {//处理css test: /\.css$/, use:[//同一文件引入多个loader必须要分开写 { loader: "style-loader" }, { loader:"css-loader" }, { loader: "postcss-loader", } ] }, ]}
// 新建的postcss.config.js文件module.exports = { plugins: [ require('autoprefixer') ]}
Babel
安装依赖模块
// 解析Es6的babel-preset-es2015包和解析JSX的babel-preset-react包npm install --save-dev babel-core babel-loader babel-preset-es2015 babel-preset-react
配置
//webpack.config.jsmodule: { rules: [ {//处理JS test: /(\.jsx|\.js)$/, use: { loader: "babel-loader", options: { presets: [ "es2015", "react" ] } }, exclude: /node_modules/ } ]}
也可以再单独的文件中进行配置
//新建的.babelrc文件{ "presets": ["react", "es2015"]}
//webpack.config.jsmodule: { rules: [ { test: /(\.jsx|\.js)$/, use: { loader: "babel-loader" }, exclude: /node_modules/ } ]}
插件
BannerPlugin 内置插件
//给打包后的js文件添加一个版权声明module.exports = {... module: { rules: [ { test: /(\.jsx|\.js)$/, use: { loader: "babel-loader" }, exclude: /node_modules/ }, { test: /\.css$/, use: [ { loader: "style-loader" }, { loader: "css-loader", options: { modules: true } }, { loader: "postcss-loader" } ] } ] }, plugins: [ new webpack.BannerPlugin('版权所有,翻版必究') ],};
HtmlWebpackPlugin
作用:根据index.html模板,自动生成一个自动引用你打包后的JS文件的新index.html
安装:
npm install --save-dev html-webpack-plugin
使用前提:
1.移除public2.在app目录下,创建一个index.tmpl.html文件模板,插件会依据此模板生成最终的html页面,会自动添加所依赖的 css, js,favicon等文件3.更新webpack的配置文件,方法同上,新建一个build文件夹用来存放最终的输出文件
配置:
const webpack = require('webpack');const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = { entry: __dirname + "/app/main.js",//已多次提及的唯一入口文件 output: { path: __dirname + "/build", filename: "bundle.js" }, ... module: { rules: [ { test: /(\.jsx|\.js)$/, use: { loader: "babel-loader" }, exclude: /node_modules/ }, { test: /\.css$/, use: [ { loader: "style-loader" }, { loader: "css-loader", options: { modules: true } }, { loader: "postcss-loader" } ] } ] }, plugins: [ new webpack.BannerPlugin('版权所有,翻版必究'), new HtmlWebpackPlugin({ template: __dirname + "/app/index.tmpl.html"//new 一个这个插件的实例,并传入相关的参数 }) ],};
使用:
//build文件夹下面生成了bundle.js和index.html执行 webpack
Hot Module Replacement
热加载模块: 在修改组件代码后,自动刷新实时预览修改后的效果。
安装react-transform-hmr:
npm install --save-dev babel-plugin-react-transform react-transform-hmr
配置文件:
1、在webpack配置文件中添加HMR插件;2、在Webpack Dev Server中添加“hot”参数;
const webpack = require('webpack');const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = { entry: __dirname + "/app/main.js",//已多次提及的唯一入口文件 output: { path: __dirname + "/build", filename: "bundle.js" }, devtool: 'eval-source-map', devServer: { contentBase: "./public",//本地服务器所加载的页面所在的目录 historyApiFallback: true,//不跳转 inline: true, hot: true//2、在Webpack Dev Server中添加“hot”参数 }, module: { rules: [ { test: /(\.jsx|\.js)$/, use: { loader: "babel-loader" }, exclude: /node_modules/ }, { test: /\.css$/, use: [ { loader: "style-loader" }, { loader: "css-loader", options: { modules: true } }, { loader: "postcss-loader" } ] } ] }, plugins: [ new webpack.BannerPlugin('版权所有,翻版必究'), new HtmlWebpackPlugin({ template: __dirname + "/app/index.tmpl.html"//new 一个这个插件的实例,并传入相关的参数 }), new webpack.HotModuleReplacementPlugin()//1、在webpack配置文件中添加HMR插件; ],};
或者,在用react时只要配置Babel:
// .babelrc{ "presets": ["react", "es2015"], "env": { "development": { "plugins": [["react-transform", { "transforms": [{ "transform": "react-transform-hmr", "imports": ["react"], "locals": ["module"] }] }]] } }}
使用:
每次保存就能在浏览器上看到更新内容
出现的报错:
1、
解决:
此时命令行所在的文件夹不是项目所在的文件夹
2、npm err!errno -4048
解决:
关掉命令行使用管理员身份重新打开
阅读全文
0 0
- Webpack入门
- webpack 入门
- webpack 入门
- webpack入门
- 入门 Webpack
- WebPack入门
- 入门Webpack
- webpack 入门
- Webpack入门
- webpack入门
- webpack 入门
- webpack 入门
- Webpack 入门
- webpack入门
- webpack入门
- webpack入门
- webpack入门
- 入门Webpack
- 80、java的IO操作-FileOutputStream
- Shiro+SpringMVC 实现更安全的登录(加密匹配&登录失败超次数锁定帐号)
- linux下修改安装版jenkins默认端口号
- LINTCODE——删除二叉查找树的节点
- spark RDD action job的提交过程之 taskSchedule
- webpack -- 入门
- 测试数据生成——树
- 人工智能(三)上——通过搜索进行问题求解(有信息搜索策略)
- 81、java的IO操作-FileInputStream
- springboot(九):定时任务
- OpenGL粒子系统详解及编程实现
- ios开发AudioUnit的录制与播放功能,双工模式下的回音抑制以及降噪
- Maven项目的导入
- FM算法详解