webpack了解
一、理解webpack
什么是webpack?
是一个模块打包器。它的主要目标是将 JavaScript 文件打包在一起,打包后的文件用于在浏览器中使用,但它也能够胜任转换(transform)、打包(bundle)或包裹(package)任何资源(resource or asset)。"
二、前期准备
1.安装
npm install --savd-dev webpack //下载
npm init -y //初始化 下载package.json 保证node是最新的
新建一个webpack.config.js文件,这里面放置的就是怎样实现打包的代码
2.我们可以更改运行webpack的命令
在package.json中有个scripts中添加 "build":"webpack" 那么执行webpack的话 就可以用 npm run build
3.webpack中各个文件的作用
package.json的作用是对webpack进行初始化
webpack.config.js是对文件夹中的文件进行操作,里面都是需要对哪些文件进行什么样子的操作
以上基本的操作完成了
三、简单实现
module.exports={
entry:{//入口文件
index:'./index.js',
vendor:['./web/jquery']
},
output:{//出口文件
path:path.resolve(__dirname,'dist'),
filename:'[name].[hash].js',//设置一个带hash的文件
},
module:{
rules:[
{//es6转es5
test:/\.js$/,
exclude:/node_modules/,
loader:'babel-loader',
query:{
presets:['es2015']
}
},
]
},
//热更新
devServer: {
inline: true,
port: 8099
},
plugins:[
new webpack.HotModuleReplacementPlugin(),//热更新
]
}
我们可以看一下,最基本的就是需要
entry:入口文件;output:出口文件;module里面放的是下载的模块和对哪些文件进行操作;plugins是引入插件
四、在项目中需要实现的功能
1、将ES6转为ES5、sass/less转成css
这种的话就是在module中的rules中执行特定的文件,并且使用对应的模块
2、多个入口多个出口
多个入口,我们需要的是使用golb设置一个全部的文件;
多个出口
path:path.resolve(__dirname,'dist'),
filename:'[name].[hash].js',//设置一个带hash的文件
3、将css文件单独打包、js文件单独打包、引入的第三方js文件单独打包、图片转为base64
(1)css单独打包成一个文件,我们需要用到一个插件:extract-text-webpack-plugin 然后再代码中这样:
module中rules
{//css
test:/\.css$/,
exclude:/node_modules/,
loader:ExtractTextPlugin.extract({ fallback: 'style-loader', use: 'css-loader' }),
//loader:ExtractTextPlugin.extract('style-loader','css-loader!postcss-loader'),
},
plugins
new ExtractTextPlugin('style.css'),//将css单独生成
(2)第三方js文件(比如jquery)
入口文件
entry:{//入口文件
index:getfile(),
vendor:['./web/jquery']
},
// plugins中
new webpack.optimize.CommonsChunkPlugin({//第三方插件
name:['vendor','manifest']
}),
4、热更新
热更新的意思是,当我们修改代码的时候,保存文件之后,webpack自动进行打包
在module.export中添加
//热更新
devServer: {
inline: true,
port: 8099
},
plugins
new webpack.HotModuleReplacementPlugin(),//热更新
代码:https://github.com/GainLoss/My-Webpack.git
=============================================
注意:
(1)在执行webpack-dev-server --open的时候,出现找不到webpack-dev-server
解决就是安装的时候用npm install webpack-dev-server -g这个命令安装 参考https://stackoverflow.com/questions/31611527/webpack-webpack-dev-server-command-not-found
要打开webpack-dev-server的时候命令必须是webpack-dev-server --open
(2)理解一下module中rules和plugins的区别:
module中rules是在打包构建过程中处理源文件,一次处理一个;
plugins是对整个构建过程进行处理
webpack了解的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- webpack之傻瓜式教程
接触webpack也有挺长一段时间了,公司的项目也是一直用着webpack在打包处理,但前几天在教新人的情况下,遇到了一个问题,那就是:尽管网上的webpack教程满天飞,但是却很难找到一个能让新人快 ...
- 细说前端自动化打包工具--webpack
背景 记得2004年的时候,互联网开发就是做网页,那时也没有前端和后端的区分,有时一个网站就是一些纯静态的html,通过链接组织在一起.用过Dreamweaver的都知道,做网页就像用word编辑文档 ...
- Webstorm+Webpack+echarts构建个性化定制的数据可视化图表&&两个echarts详细教程(柱状图,南丁格尔图)
Webstorm+Webpack+echarts ECharts 特性介绍 ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(I ...
- 使用webstorm+webpack构建简单入门级“HelloWorld”的应用&&引用jquery来实现alert
使用webstorm+webpack构建简单入门级"HelloWorld"的应用&&构建使用jquery来实现 1.首先你自己把webstorm安装完成. 请参考这 ...
- webpack入门教程之Hello webpack(一)
webpack入门教程系列为官网Tutorials的个人译文,旨在给予想要学习webpack的小伙伴一个另外的途径.如有不当之处,请大家指出. 看完入门教程系列后,你将会学习到如下内容: 1.如何安装 ...
- webpack的使用
1.webpack是什么? 打包前端项目的工具(为项目提高逼格的东西). 2.webpack的基本命令 webpack#最基本的启动webpack命令 webpack-w #提供watch方法,实时进 ...
- Webpack 配置摘要
open-browser-webpack-plugin 自动打开浏览器 html-webpack-plugin 通过 JS 生成 HTML webpack.optimize.UglifyJsPlugi ...
- Vue + Webpack + Vue-loader 系列教程(2)相关配置篇
原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ 使用预处理器 在 Webpack 中,所有的预处理器需要和一个相应的加载器一同使用.vue- ...
- Vue + Webpack + Vue-loader 系列教程(1)功能介绍篇
原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ Vue-loader 是什么? vue-loader 是一个加载器,能把如下格式的 Vue ...
随机推荐
- poj1094 拓扑排序(出度入度简单使用)
Sorting It All Out Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 37764 Accepted: 13 ...
- 查看当前linux有多少http连接数
已采纳 1.查看apache当前并发访问数: #对比httpd.conf中MaxClients的数字差距多少.netstat -an | grep ESTABLISHED | wc -l 2.查看ht ...
- 问题:git add 遇到 warning: LF will be replaced by CRLF in 警告(已解决)
问题描述: git add file_name 提交文件时候提示 自动转换 CRLF 标识 如下图: 解决方法: 执行下面代码在命令行中执行: git config --global core.aut ...
- 25-----BBS论坛
BBS论坛(二十五) 25.1.发布帖子后台逻辑完成 (1)apps/models.py class PostModel(db.Model): __tablename__ = 'post' id = ...
- Vue.js-----轻量高效的MVVM框架(五、计算属性)
#基础例子 <div id="dr01"> <h4>#基础例子</h4> <div> num01={{num01}}, num02= ...
- 在本地安装oracle-maven库
mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc14 -Dversion=10.2.0.4.0 -Dpackaging= ...
- jQuery源码解读 --- 整体架构
最近学习比较忙,感觉想要提高还是要读源码,所以准备考试这个考试结束就开始读jquery源码啦,加油~
- c++ 面试整理
1. 继承方式 public 父类的访问级别不变 protected 父类的public成员在派生类编程protected,其余的不变 private 父类的所有成员变成pr ...
- php-fpm 进程在云服务器cpu分配不均匀
8核的云服务器,开了200个php-fpm进程,用top命令查看 大部分进程都在cpu 0 上跑着,导致其他cpu 负载很低,cpu分配不均匀: 使用shell 解决问题: 列出所有php-fpm ...
- GitKraken使用教程-基础部分(7)
8. 本地分支和标签 1) 在提交记录区中查看分支状态 提交记录区中每一个分支都位于一个提交记录所在的行中. 从图 2‑1中可以看到,服务器上的master分支停留在整理格式(把这个提交记录记为or ...