本篇内容

  • 前言
  • 配置入口和输出
  • 热更新
  • loader配置
  • js代码压缩
  • html的打包与发布
前言
//全局安装
npm install -g webpack(3.6.0) npm init //安装到你的项目目录
npm install --save-dev webpack //本地化安装是防止全局的版本冲突,团队配合时也应注意node跟webpack版本的统一性 //在package.json中
"dependencies": {
//生产环境相关依赖 cnpm i -S/--save xxx
},
"devDependencies": {
//开发环境相关依赖 cnpm i -D/--save-dev xxx
} //另:
cnpm i -g live-server //使用:
live-server //(直接到开服务器进入项目根目录)
webpack.config.js配置入口和输出
//新建工程主文件夹
md src
echo >> main.js
echo >> index.html
//根目录下配置文件
cd ../
echo >> webpack.config.js const path=require('path');
module.exports={
entry:{
main:'./src/main.js', //键名决定打包后的名字
main2:'./src/main2.js', //多入口
},
output:{
path:path.resolve(__dirname,'dist'),
filename:'[name].js' //根据入口名字生成相应的文件
},
module:{},
plugins:[],
devServer:{}
} webpack 即可打包查看结果
热更新(该方式页面会刷新)
cnpm i -D webpack-dev-server(2.8.2)   

//配置热更新
devServer:{
contentBase:path.resolve(__dirname,'dist'),
host:'192.168.1.122',
compress:true, //压缩
port:1234
} //在package.json中
"scripts": {
"server": "webpack-dev-server" //--open直接运行并打开浏览器'webpack-dev-server --open'
}, //运行
npm run server

如果热更新有问题,另加插件

plugins: [
//...
new webpack.HotModuleReplacementPlugin(), //webpack自带
loader配置

如:style-loader css-loader

cnpm i -D style-loader css-loader

// webpack.config.js
module:{
rules:[
{
test:/\.css$/, //要匹配的文件后缀名
loaders:['style-loader','css-loader']
// include/exclude //(需要处理/不需要处理)
}
]
},
//main.js
import css from './css/index.css'; //被打包再js文件中 //运行
npm run server
js代码压缩
const uglify=require('uglifyjs-webpack-plugin');

plugins:[
new uglify()
],
html的打包与发布(在此之前并不能直接生成html文件,在dist中,.js文件也为注入)
cnpm i -D html-webpack-plugin

const htmlPlugin=require('html-webpack-plugin');

plugins:[
// new uglify()
new htmlPlugin({
minify:{ //压缩
removeAttributeQuotes:true //去除标签属性的''
},
hash:true, //防止缓存的影响
template:'./src/index.html'
})
], //运行
webpack

注意:

cnpm i live-server  //注意:与cnpm i -g live-server效果一样

cnpm i --production //只安装生产环境的安装包

项目地址:https://github.com/adoctors/webpack-3.6.0-demo1

webpack@3.6.0(1) -- 快速开始的更多相关文章

  1. Spring Boot 2.0 的快速入门(图文教程)

    摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! Spring Boot 2.0 的快速入门(图文教程) 大家都 ...

  2. .Net Core 3.0 IdentityServer4 快速入门

    .Net Core 3.0 IdentityServer4 快速入门 一.简介 IdentityServer4是用于ASP.NET Core的OpenID Connect和OAuth 2.0框架. 将 ...

  3. .Net Core 3.0 IdentityServer4 快速入门02

    .Net Core 3.0 IdentityServer4 快速入门 —— resource owner password credentials(密码模式) 一.前言 OAuth2.0默认有四种授权 ...

  4. webpack入门级 - 从0开始搭建单页项目配置

    前言 webpack 作为前端最知名的打包工具,能够把散落的模块打包成一个完整的应用,大多数的知名框架 cli 都是基于 webpack 来编写.这些 cli 为使用者预设好各种处理配置,使用多了就会 ...

  5. WPF 4.0 DatePicker 快速录入

    WPF 4.0的DatePicker在通过键盘录入日期的时候是非常让人郁闷的.必须按照日期的格式来完整输入例如,比如输入“2010/10/10”才能识别.而实际上在一些要求快速录入的场合,用户更希望直 ...

  6. 【翻译】Webpack 4 从0配置到生产模式

    查看原文 webpack 4 发布了! webpack 4 作为一个零配置的模块打包器 webpack 是强大的并且有许多独一无二的特点但是有一个痛点就是配置文件. 在中型到大型项目中为webpack ...

  7. webpack打包vue2.0项目时必现问题(转载)

    原文地址:http://www.imooc.com/article/17868 [Vue warn]: You are using the runtime-only build of Vue wher ...

  8. Spring Boot 2.0 教程 | 快速集成整合消息中间件 Kafka

    欢迎关注个人微信公众号: 小哈学Java, 每日推送 Java 领域干货文章,关注即免费无套路附送 100G 海量学习.面试资源哟!! 个人网站: https://www.exception.site ...

  9. Android7.0 添加快速设定Quick Settings Tile

    Android7.0新推出了一个非常实用的功能--添加快速设定(或者翻译成快速设置),但是感觉社区里关注的人比较少,可能目前为止国内还没有Android7.0的手机,但是越早接触越好,甚至可以告诉产品 ...

随机推荐

  1. BZOJ 3943 [Usaco2015 Feb]SuperBull:最大生成树

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3943 题意: 有n只队伍,每个队伍有一个编号a[i]. 每场比赛有两支队伍参加,然后选一支 ...

  2. git内部原理-第一篇

    本人计划写一些关于<git内部原理>的文章 计划每周一篇

  3. mfc创建文档视图过程

    一.如何创建文档视图界面: 创建新的文档视图界面,只需要调用CDocTemplate::OpenDocumentFile(strpath)即可.(strpath为要打开的文档路径,如果是NULL,则生 ...

  4. CI中控制器名不能和本个 控制器中的方法名相同

    控制器名称:application/controllers/tang.php 控制器中方法名称:application/controllers/role.php  中有方法 public  funct ...

  5. Gym - 100570C: Subrect Query (巧妙的单调队列)

    De Prezer loves rectangles.He has a n × m rectangle which there is a number in each of its cells. We ...

  6. ACM学习历程—HDU5423 Rikka with Tree(搜索)

    Problem Description As we know, Rikka is poor at math. Yuta is worrying about this situation, so he ...

  7. Poj 1742 Coins(多重背包)

    一.Description People in Silverland use coins.They have coins of value A1,A2,A3...An Silverland dolla ...

  8. Poj1163 The Triangle(动态规划求最大权值的路径)

    一.Description 7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 (Figure 1) Figure 1 shows a number triangle. Write a pro ...

  9. C# 利用委托和事件 传入一个参数进行进行计算并返回结果

    一.委托定义 1: public class TestData 2: { 3: //定义委托 4: public delegate void Get_TestDataEventHandler(Get_ ...

  10. #np.random.normal,产生制定分布的数集(默认是标准正态分布)

    http://docs.scipy.org/doc/numpy/reference/generated/numpy.random.normal.html #np.random.normal,产生制定分 ...