webpack学习笔记
1.安装webpack
npm install webpack -g
2.进入项目目录,初始化
npm init
3.将webpack安装到项目依赖中
npm install webpack --save-dev
4.创建一个webpack.config.js配置文件
module.exports = {
// 需要编译的文件
entry:{
index1:'./src/index1.js',
index2:'./src/index2.js'
},// 编译配置项
output:{// 输出到哪个目录
path:'./dire',// 文件名 [name]会根据entry的键名来取值
filename:'[name].js'
}
};
目录结构:






5.cmd中输入:webpack
结果会生成一个dire目录。

OK,完成。
我们看看里面生成的代码。

乱七八糟的,如果想去掉这些可以这样。
var webpack = require('webpack');
module.exports = {
entry:{
index1:'./src/index1.js',
index2:'./src/index2.js'
},
plugins:[
new webpack.optimize.UglifyJsPlugin()
],
output:{
path:'./dire',
filename:'[name].js'
}
};
好像没啥用对吧,我们可以这样。
webpack小试身手,模块化开发。
目录结构





module.exports = {
entry:'./main.js',
plugins:[
new webpack.optimize.UglifyJsPlugin()
],
output:{
path:'./dire',
filename:'main.js'
}
};
这里将main.js做为主模块,我们可以在main.js里面将需要用到的js文件通过require引入进来,达到模块化的需求,这个require的用法和nodejs一样。
当然你可以划分成多个模块,你只需要更改一下这个。
module.exports = {
entry:{xx:'./xx/xx.js',
xx:'./xx/xx.js'
.......
},
plugins:[
new webpack.optimize.UglifyJsPlugin()
],
output:{
path:'./dire',
filename:'[name].js'
}
};
这样你就可以根据不同模块编写JS代码了。真不错。
但这都只是冰山一角,来看看webpack更强大的功能。
在main.js中导入css文件。
main:require('./src/index.css');
但是发现报错了,我们需要配置一下webpack.config.js
编译css
var webpack = require('webpack');
module.exports = {
entry:'./main.js',
plugins:[
new webpack.optimize.UglifyJsPlugin({
compress:{//去除控制台错误
warnings:false
}
})
],
output:{
path:'./dire',
filename:'main.js'
},
module:{
loaders:[
{test:/\.css$/,loader:'style-loader!css-loader'}
]
}
};
还得安装一下
npm install style-loader css-loader --save-dev
在main.js里面使用less文件。
require('./src/index.css');
require('./src/less.less');
需要进行如下配置:
loaders:[
{ test: /\.less$/, loader: 'style-loader!css-loader!less-loader' },
{ test: /\.css$/, loader: 'style-loader!css-loader' }
]
还得安装style-loader,css-loader,less-loader
npm install style-loader css-loader less-loader --save-dev
我安装完,webpack编译less文件的时候发现报错了。原来是还得安装一下less.

npm install less --save-dev
来看一下页面的效果:

我们用require过来的css文件变成style样式。
除了这个,我们还可以用来处理图片,将图片转成base64
main.js
require('./src/index.css');
require('./src/less.less');
var img = document.createElement('img');
img.src = require('./src/baidu.png');var box = document.getElementById('box');
box.appendChild(img);
webpack.config.js
loaders:[
{ test: /\.less$/, loader: 'style-loader!css-loader!less-loader' },
{ test: /\.css$/, loader: 'style-loader!css-loader' },
{ test: /\.(png|jpg)$/, loader: 'url-loader?limit=8192' }
]
limit:表示图片小于多少就转成base64格式的图片。
使用前我们还得安装一下url-loader
npm install url-loader --save-dev
webpack
看看效果

生成base64位了噢。
在css,less中都是可以使用的噢。

less代码
ul{
li{
width:200px;
height:200px;
color:red;
font-size:18px;
background:url(./baidu.png) no-repeat;
}
}
webpack实在太棒了。
如果你想编译其他格式的文件使用方法都差不多,这里就不试了。
通过webpack --watch监听文件变化自动打包。
webpack学习笔记的更多相关文章
- 【原】webpack学习笔记
之前在react的项目中有用过webpack,不过没有认真的去研究,这段时间又重新好好的学习一下webpack,发觉 webpack是一个很强大的东西.而且很好用,方便,接下来主要是做一下学习的笔记 ...
- 更博不能忘——webpack学习笔记
webpack是前端构建系统就像grunt和gulp(之前有学习过grunt所以也就大概明白webpack是个什么东西),所以说前端技术大部分还真是相通的,现在觉得当时多看的东西并不白费,虽然长时间不 ...
- webpack学习笔记(二)-- 初学者常见问题及解决方法
这篇文章是webpack学习第二篇,主要罗列了本人在实际操作中遇到的一些问题及其解决方法,仅供参考,欢迎提出不同意见. 注:本文假设读者已有webpack方面相关知识,故文中涉及到的专有名词不做另外解 ...
- webpack学习笔记一:安装webpack、webpack-dev-server、内存加载js和html文件、loader处理非js文件
一 .webpack学习环境准备: 1:window系统 2:安装node.js 官方网址 下载好后下一步下一步安装即可 安装步骤略过....... 3:nrm的安装 打开cmd命令控制台 输入:n ...
- Webpack学习笔记九 webpack优化总结
webpack 优化笔记 webpack4 自带的优化包括 swingTree(摇摆树)和作用域提升 swingTree 比如入口文件 index.js引入通用方法 util, 里面有 10个方法, ...
- Webpack学习笔记一:What is webpack
#,Loaders干嘛的,webpack can only process JavaScript natively, but loaders are used to transform other ...
- webpack学习笔记—webpack安装、基本配置
文章结构: 什么是webpack? 安装webpack 'webpack基本配置 一.什么是webpack? 在学习react时发现大部分文章都是react和webpack结合使用的,所以在学reac ...
- 【webpack学习笔记】a04-建立开发环境
开发环境就是在开发过程中为了方便配置的环境,生产环境就是开发完成即将上线的情况. 好了,说了句废话,切入正题. 在开发时,打包后的文件压缩成一团,报错调试的时候傻眼了有木有?每次做出修改需要到浏览器查 ...
- Webpack 学习笔记总结
Webpack安装 Linux系统默认已经安装了node&npm,但版本比较低,而且没法升级,可以重新下载Node然后通过软链接替换系统自带的node和npm; ln -s /path_to/ ...
- webpack学习笔记丁点积累
webpack是什么? https://webpack.js.org/concepts/ https://code.tutsplus.com/tutorials/introduction-to-web ...
随机推荐
- React Native填坑之旅--class(番外篇)
无论React还是RN都已经迈入了ES6的时代,甚至凭借Babel的支持都进入了ES7.ES6内容很多,本文主要讲解类相关的内容. 构造函数 定义侦探类作为例子. ES5的"类"是 ...
- 【MySQL】MySQL中where条件的执行分析
1.问题描述 一条SQL,在数据库中是如何执行的呢?相信很多人都会对这个问题比较感兴趣.当然,要完整描述一条SQL在数据库中的生命周期,这是一个非常巨大的问题,涵盖了SQL的词法解析.语法解析.权限检 ...
- NBUT 1535
题意:往一个塔里放数,取数,找第 k 个大的数 刚开始用 stack 做的,不知道怎样找第 k 个数 又想到用 vector ,以前用过 注释有点多吧 ...... 代码如下: #include&l ...
- 【转】使用Fiddler进行HTTP断点调试。
这是Fiddler又一强大和实用的工具之一.通过设置断点,Fiddler可以做到: 1. 修改HTTP请求头信息.例如修改请求头的UA, Cookie, Referer 信息,通过“伪造”相应信息达到 ...
- 屏幕适配1(Android 增强版百分比布局库 为了适配而扩展)
转载请标明出处: http://blog.csdn.net/lmj623565791/article/details/46767825: 本文出自:[张鸿洋的博客] 这篇博文写得太好了,让我很激动,分 ...
- mysql 按时间段统计(年,季度,月,天,时)
按年汇总,统计: select sum(mymoney) as totalmoney, count(*) as sheets from mytable group by date_format(col ...
- 【设计模式之装饰者模式InJava】
需求:定义一个操作系统OS接口,安装Windows10操作系统,在上面安装虚拟机VMWare,虚拟机里装Linux; 然后在Linux中安装虚拟机VMware,再在虚拟机里安装MacOS操作系统. 实 ...
- PN结的单向导电性及PN结的电流方程及PN结电容
PN结加正向电压 当PN结外加正向电压时,外电场将多数载流子推向空间电荷区,使其变窄,削弱了内电场,破坏了原来的平衡,使扩散运动加剧,PN结导通.PN结的压降只有零点几付,所以在其回路里应串联一个电阻 ...
- 0002--Weekly Meeting on 27th March and 3th April, 2015
27th March, 2015 (1) RankNet && PageRank ->reporter: jinquan Du Web_RankNet Web_PageRa ...
- haproxy的使用
假如 www.example.com想要使用haproxy作为代理,则要在自己的 dns服务器设置AAAA记录对应于haproxy机器的IP. 这样访问www.example.com其实就访问了hap ...