webpack 3 零基础入门教程

http://webpackbook.rails365.net/466996(文本)

https://www.rails365.net/movies/webpack-3-ling-ji-chu-ru-men-shi-pin-jiao-cheng-1-jie-shao (视频)

项目文件夹:

根目录:

src下的目录:

dist下打包后生成的目录:

下面是详细的流程步骤:

1、建立项目名

mkdir 项目名

2、定位项目名里面

cd 项目名

3、生成package.json文件

npm init --yes

4、安装webpack( 不加版本号默认为2.0以上 )

cnpm install webpack --save-dev

5、生成依赖包,即node_modules目录 ( 生成一小部分,后面需安装各种包,不像vue-cli本身就集成很多 )

cnpm install

6、建立src和dist文件夹,src目录下建styles和scripts( 可省略此步,手动新建 )

mkdir src mkdir dist ……

7、根目录下建立index.html,并暂时引入出口文件bundle.js( 前期预览效果,后面会自动引入 )

8、根目录建立webpack.config.js,先定义进出口文件对应的目录及随便写entry文件的内容

module.exports = {
entry: {
main: './src/scripts/main.js',
aaa: './src/scripts/aaa.js',
bbb: './src/scripts/bbb.js',
ccc: './src/scripts/ccc.js'
},
output: {
path: path.resolve(__dirname,'./dist'),
filename: 'js/[name]-bundle.js'
}

9、初次执行打包命令,可看到dist下生成打包后的js文件

直接在命令行输入 'webpack'   ( 后面每一步操作都要webpack一下才可看到效果 )
'webpack --display-error-details' : 出错时错误的详情
'webpack -w' : 提供watch方法,实时进行打包更新( 推荐加上-w )
'webpack -p' : 对打包后的文件进行压缩
'webpack -d' : 提供SourceMaps,方便调试

10、生成页面中的html,安装html-webpack-plugin插件并配置好

cnpm install html-webpack-plugin --save-dev
module.exports = {
plugins: [
//根目录的index.html生成dist下的html,多new几个就可多个页面生成
new htmlWebpackPlugin({
filename: 'index.html',
template: 'index.html',
inject: 'body', //script标签的放置
title: 'index title test',
minify: { //html压缩
removeComments: true, //移除注释
collapseWhitespace: true //移除空格
}
//chunks: ['main','aaa'], //生成html页面后的script文件的引入
//排除没有用到的script文件,其他的都引进来,比chunks更好匹配
excludeChunks: ['bbb','ccc'] //引入了main.js和aaa.js
})
}

11、接下来安装各种loader及配置:

js的loader安装:

cnpm install babel-preset-latest --save-dev
cnpm install babel loader babel-core babel-plugin-transform-runtime babel-preset-es2015 babel-runtime --save-dev

css的loader安装:

cnpm install style-loader css-loader --save-dev
//css3前缀补全:
cnpm install postcss-loader --save-dev
cnpm install autoprefixer --save-dev

sass的loader安装:

cnpm install sass-loader node-sass webpack --save-dev

模板中的loader安装:

cnpm install html-loader --save-dev  ( html )
cnpm install ejs-loader --save-dev ( ejs )

图片:

cnpm install file-loader --save-dev

url:

cnpm install url-loader --save-dev

图片压缩:

cnpm install image-webpack-loader --save-dev

大体配置格式:

module.exports = {
module: {
rules: [
//处理js中的loader
{
test: /\.js$/,
loader: 'babel-loader',
include: path.resolve(__dirname,'/src'),
exclude: path.resolve(__dirname,'/node_modules')
},
//处理css中的loader
{
test: /\.css$/,
loader: 'style-loader!css-loader?importLoaders=1!postcss-loader'
},
//处理sass中的loader
{
test: /\.scss$/,
loader: 'style-loader!css-loader!postcss-loader!sass-loader'
},
//处理html模板中的loader
{
test: /\.html$/,
loader: 'html-loader'
},
//处理ejs模板中的loader,以.tpl后缀结尾的
{
test: /\.tpl$/,
loader: 'ejs-loader'
},
//处理图片中的loader( 通常url/file/image-webpack等loader配合 )
{
test: /\.(png|jpg|gif|svg)$/i,
loader: 'file-loader'
}
]
}
}
css3前缀要放在插件里,与webpack1的用法不同
module.exports = {
plugins: [
new webpack.LoaderOptionsPlugin({
options: {
postcss: [
require("autoprefixer")({
browsers: ["last 5 versions"]
})
]
}
})
]
}
最终的webpack.config.js配置如下:
 var webpack = require("webpack");
var path = require("path");
var htmlWebpackPlugin = require("html-webpack-plugin"); module.exports = {
entry: './src/app.js', /*{
main: './src/scripts/main.js',
aaa: './src/scripts/aaa.js',
bbb: './src/scripts/bbb.js',
ccc: './src/scripts/ccc.js'
}*/
output: {
path: path.resolve(__dirname,'./dist'),
filename: 'js/[name]-bundle.js',
publicPath: 'http://cdn.com/' //上线的绝对路径
},
//插件
plugins: [
new htmlWebpackPlugin({ //根目录的index.html生成dist下的html,可以多个生成
filename: 'index.html',
template: 'index.html',
inject: 'body', //script标签的放置
//title: 'index title test',
minify: { //html压缩
removeComments: true, //移除注释
collapseWhitespace: true //移除空格
}
//chunks: ['main','aaa'], //生成html页面后的script文件的引入
//excludeChunks: ['bbb','ccc'] //排除没有用到的script文件,其他的都引进来,比chunks更好匹配
}),
new webpack.LoaderOptionsPlugin({
options: {
postcss: [ //浏览器自动补全前缀
require("autoprefixer")({
browsers: ["last 5 versions"]
})
]
}
})
/*,
new htmlWebpackPlugin({
filename: 'b.html',
template: 'index.html',
inject: 'body',
title: "this is b.html",
//chunks: ['bbb'],
//excludeChunks: ['aaa','ccc']
}),
new htmlWebpackPlugin({
filename: 'c.html',
template: 'index.html',
inject: 'body',
title: "this is c.html",
//chunks: ['ccc'],
//excludeChunks: ['aaa','bbb']
})*/
],
module:{
rules: [ //1.0的是loaders
//处理js中的loader
{
test: /\.js$/,
loader: 'babel-loader',
include: path.resolve(__dirname,'/src'), //指定打包的文件
exclude: path.resolve(__dirname,'/node_modules') //排除打包的文件,加速打包时间
},
//处理css中的loader
{
test: /\.css$/,
loader: 'style-loader!css-loader?importLoaders=1!postcss-loader' //@import进来的样式在问号后加
},
//处理sass中的loader
{
test: /\.scss$/,
loader: 'style-loader!css-loader!postcss-loader!sass-loader'
},
//处理html模板中的loader
{
test: /\.html$/,
loader: 'html-loader'
},
//处理ejs模板中的loader,以.tpl后缀结尾的
{
test: /\.tpl$/,
loader: 'ejs-loader'
},
//处理图片中的loader,file-loader,url-loader,image-webpack-loader相互配合(图片格式转换base64 图片压缩)
{
test: /\.(png|jpg|gif|svg)$/i, //模板中的图片放相对路径: src="${require('../imgs/aaa.jpg')}"
loader: 'url-loader'
}
]
} }
配置后的东西可以在这里看到package.json( 也可在这里设置其他 ):
{
"name": "webpack-demo",
"version": "2.0.0",
"description": "wabpack demo",
"main": "index.js",
"babel": {
"presets": [
"latest"
]
},
"scripts": {
"dev": "cross-env NODE_ENV=development webpack-dev-server --open --hot --port 8081",
"build": "cross-env NODE_ENV=production webpack --progress --colors --display modules --display reason --hide-modules"
},
"keywords": [
"wabpcck"
],
"author": "wu",
"license": "ISC",
"devDependencies": {
"autoprefixer": "^6.7.7",
"babel": "^6.23.0",
"babel-core": "^6.24.0",
"babel-plugin-transform-runtime": "^6.23.0",
"babel-preset-es2015": "^6.24.0",
"babel-preset-latest": "^6.24.0",
"babel-runtime": "^6.23.0",
"css-loader": "^0.28.0",
"ejs-loader": "^0.3.0",
"file-loader": "^0.11.1",
"html-loader": "^0.4.5",
"html-webpack-plugin": "^2.28.0",
"image-webpack-loader": "^3.3.0",
"imagemin-pngquant": "^5.0.0",
"install": "^0.8.8",
"loader": "^2.1.1",
"node-sass": "^4.5.2",
"postcss-loader": "^1.3.3",
"sass-loader": "^6.0.3",
"style-loader": "^0.16.1",
"url-loader": "^0.5.8",
"webpack": "^2.3.3"
}
}

作者:晨光2016
链接:https://www.jianshu.com/p/87a9ba0a5c73
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
 

纯webpack打包项目的更多相关文章

  1. 如何使用webpack打包项目

    webpack是前端开发中比较常用的打包工具之一,另外还有gulp,grunt.之前没有涉及过打包这块,这里介绍一下使用webpack打包的流程. Grunt和Gulp的工作方式是:在一个配置文件中, ...

  2. 【vue】饿了么项目-使用webpack打包项目

    1.vue cli给我们提供了npm run build命令打包项目,在packa.json文件中scripts对象中有build属性,当我们执行npm run build时,就执行build对应的& ...

  3. vue和webpack打包 项目相对路径修改

    一般vue使用webpack打包是整个工程的根目录,但是很多情况下都是把vue打包后的文件在某子目录下. 修改: 1,打开index.js assetsPublicPath:'/' 改为: asset ...

  4. 实践2:github管理代码仓库,包含用webpack打包项目

    此篇介绍用github仓库管理代码,github是大型的项目代码管理,存储平台:简单说帮助一个团队共享,修改同一个项目,配合着gitHub Desktop非常方便: 可以做到多人删除.修改.增加同一项 ...

  5. 0基础手把手教你搭建webpack运行打包项目(未完待续)

    这些天在项目之余的时间学习了webpack打包项目的东西,非常荣幸的找到一些大神的文章来学习,死劲嚼了几天,终于略知一二.在以后的工作上还需继续学习,下面我将分享我这几天学到的一点东西,希望能让我一个 ...

  6. 如何使用webpack打包你的项目

    webpack是前端开发中比较常用的打包工具之一,另外还有gulp,grunt.之前没有涉及过打包这块,这里介绍一下使用webpack打包的流程. Grunt和Gulp的工作方式是:在一个配置文件中, ...

  7. 零基础学习webpack打包管理

    这些天在项目之余的时间学习了webpack打包项目的东西,非常荣幸的找到一些大神的文章来学习,死劲嚼了几天,终于略知一二.在以后的工作上还需继续学习,下面我将分享我这几天学到的一点东西,希望能让我一个 ...

  8. webpack打包生成多个vendor的配置方法

    用webpack打包项目的时候,一般喜欢把一些公用的库打包的vendor.js里面,比如像react,react-router,redux等. 随着引入的库越来越多,vendor文件也变得越来越大,于 ...

  9. 基于ES6模块标准通过webpack打包HTM5项目

    本篇主要演示通过webpack打包phaser项目,webpack安装方法在此处就不一一赘述了 经常用phaser来写html5游戏的朋友可能会发现,当游戏场景比较多时,如果都写在一个js文件中那么将 ...

随机推荐

  1. IP白名单

    一.什么是IP白名单 公众平台后台新增了IP白名单功能.通过开发者ID及密码调用获取access_token接口时,需要设置访问来源IP为白名单. IP白名单是指一组IP列表,只有该列表中的IP地址的 ...

  2. jQuery two way bindings(双向数据绑定插件)

    jQuery two way bindings https://github.com/petersirka/jquery.bindings 这是一个简单的jQuery双向绑定库. 此插件将HTML元素 ...

  3. Eclipse下生成/编辑Java类图或时序图(UML)[转载]

    一 引用文章 1.[eclipse下生成Java类图和时序图,生成UML图(更完整版)](https://blog.csdn.net/guomainet309/article/details/5302 ...

  4. 调用kaldi的模型进行解码

    At the moment Kaldi is targeted more at people who are building ASR systems than those who just want ...

  5. Dan版本的nnet2

    除了chain,nnet1, nnet2, nnet3训练时调整转移模型,chain模型使用类似与MMI的训练准则 Dan's setup does not uses pre-training. Da ...

  6. service cloudera-scm-server restart报错 Unable to retrieve remote parcel repository manifest

    Unable to retrieve remote parcel repository manifest 1 详细错误 ERROR ParcelUpdateService:com.cloudera.p ...

  7. ASP.NET MVC中注册Global.asax的Application_Error事件处理全局异常

    在ASP.NET MVC中,通过应用程序生命周期中的Application_Error事件可以捕获到网站引发的所有未处理异常.本文作为学习笔记,记录了使用Global.asax文件的Applicati ...

  8. Kotlin中与Java不同的地方 需要注意

    1. 在Kotlin中不会将基本数据类型的自动转型比如 scriptIntrinsicBlur.setRadius(25) //报错, 必须写成 25f 或者 调用.toFloat() 2.Kotli ...

  9. 解释下面URL

    解释下面URL各部分的含义 a.duke.csc.villanova.edu/jss/examles.html duke是计算机名,该计算机属于villanova.edu域的csc子域.edu是最高级 ...

  10. linux 用户管理命令