前言

随我来,去看看webpack!(为时未晚)============》第一版(较浅显的知识,懂得可忽略本文)


方向

  1. 安装,起步搭建运行. (粗略代过)
  2. 对于资源的管理,对于输出的管理. (举例介绍)
  3. 本地开发 (基础服务)
  4. 热更新=[模块热替换] (初步认识)

1.初步构建

mkdir webpack_demo && cd webpack_demo   // 新建一个文件 并进入更目录 `mkdir 是linux命令`
npm init -y // 初始一个packjage.json文件 -y 表示跳过询问步骤... //安装webpack
npm install webpack --save-dev // 添加webpack-cli依赖到"devDependencies"
//webpack4.0+ 需要安装webpack-cli
npm install webpack-cli --save-dev // 添加webpack-cli依赖到"devDependencies" </pre>

//生成如下目录

├── package.json

├── src //源目录(输入目录)

│   ├── index.js

├── dist // 输出目录

│   ├── index.html

// 修改 `dist/index.html`
&lt; !DOCTYPE html&gt;
&lt;html lang="en"&gt;
&lt;head&gt;
&lt;meta charset="UTF-8"&gt;
&lt;title&gt;webpack_demo&lt;/title&gt;
&lt;/head&gt;
&lt;body&gt;
&lt;script src="main.js"&gt;&lt;/script&gt; //为什么是main.js下面会解释
&lt;/body&gt;
&lt;/html&gt; //修改`src/index.js `
function component() {
var element = document.createElement('div');
element.innerHTML = "整一个盒子"
return element;
} document.body.appendChild(component());</pre>
<blockquote>
<code> npx webpack</code> (Node 8.2+ 版本提供的 npx 命令) <br><code>node node_modules/.bin/webpack</code> (8.2-版本)</blockquote>
<h5>会将我们的脚本作为<code>入口起点</code>,然后 输出 为 <code>main.js</code>.</h5>
<blockquote>
<code>打开dist/index.html 你将会看到 </code>整一个盒子<code> 几个字样~</code>
</blockquote>
<h3>2.资源管理,输出管理.基本开发起步</h3>

//生成如下目录

├── package.json

  • |── webpack.config.js //webpack配置文件

    ├── src //源目录(输入目录)

    │   ├── index.js

    ├── dist // 输出目录

    │   ├── index.html

先介绍一个Lodash库 它是一个一致性、模块化、高性能的 JavaScript 实用工具库 模块化处理非常适合值操作和检测(说白了就是webpack用了我也试试...)
lodash相关文档

npm install lodash --save //非仅在开发的时候使用的依赖 就是需要打包到生产环境的包 不加-dev


// src/index.js
import _ from 'lodash'; function component() {
var element = document.createElement('div');
element.innerHTML = _.join(['lodash','webpack'],''); //join将 array 中的所有元素转换为由''分隔的字符串 其它函数可以自己实践
return element;
}</pre>
<blockquote><code>打开index页面输出 loadshwebpack</code></blockquote>

//webpack.config.js

const path = require('path');

module.exports = {

entry: './src/index.js', //入口

output: { //出口

filename: 'main.js', //打包之后脚本文件名称

path: path.resolve(__dirname, 'dist') //路径指向执行 js 文件的绝对路径 此处为/dist

}

};

执行npx webpack --config webpack.config.js (把之前dist目录下main.js删除) 新的脚本生成(其实没多大变化..)

//  配置一下package.json
"scripts": {
"test": "echo \"Error: no test specified\" &amp;&amp; exit 1",
"build": "webpack" //添加此行命令 下次执行打包就是 npm run build 相当于上面的npx webpack --config webpack.config.js
}, // 资源的配置 css 图片 js等等.. 举例 css 图片
</pre>
<blockquote>
<code>npm install --save-dev style-loader css-loader</code> css的loader<br><code>npm install --save-dev file-loader</code> file(图片)对象的 loader</blockquote>

//生成如下目录

├── package.json

  • |── webpack.config.js //webpack配置文件

    ├── src //源目录(输入目录)

    │   ├── index.js
  • │   ├── index.css
  • │   ├── icon.jpg

    ├── dist // 输出目录

    │   ├── index.html
//修改webpack.config.js
const path = require('path'); //path路径模块
module.exports = {
entry: './src/index.js', //入口
output: { //出口
filename: 'main.js',
path: path.resolve(__dirname, 'dist')
},
module: {
rules: [
{
test: /\.css$/, //检测正则匹配.css结尾的文件
use: [ //使用俩个loader
'style-loader',
'css-loader'
]
},
{
test: /\.(png|svg|jpg|gif)$/, //正则匹配.png svg jpg gif结尾的文件
use: [ //使用file-loader
'file-loader'
]
}
]
}
};
//修改src/index.css
div{
color:red;
} //修改src/index.js
import _ from 'lodash';
import "./index.css";
import Icon from './icon.jpg'; function component() {
var element = document.createElement('div'); element.innerHTML = _.join(['loadsh', 'webpack'], ' ');
var myIcon = new Image();
myIcon.src = Icon; element.appendChild(myIcon);
return element;
} document.body.appendChild(component());
</pre>
<blockquote>
<code>npm run build(删除之前的dist目录下main.js) 你会看红字和图片</code> 以上就是资源管理的简短介绍</blockquote>
<blockquote>
<code>npm install --save-dev html-webpack-plugin 安装html-webpack-plugin模块</code> 模块用到功能:<br> 1: 动态添加每次compile后 js css 的hash<br> 2: 可配置多页面 单页面 这些 <br> 3: 其它没涉及到<br><code>npm install clean-webpack-plugin --save-dev 清除dist文件夹(每次删除麻烦了..)</code>配置一下</blockquote>

//修改目录

├── package.json

|── webpack.config.js //webpack配置文件

├── src //源目录(输入目录)

  • │   ├── app.js
  • │   ├── print.js

    │   ├── index.css

    │   ├── icon.jpg

    ├── dist // 输出目录

    │   ├── index.html
//webpack.config.js  ===============================================
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin'); module.exports = {
entry: {
app: './src/index.js',
print: './src/print.js'
},
output: {
filename: '[name].bundle.js',
path: path.resolve(__dirname, 'dist')
},
plugins: [
new CleanWebpackPlugin(['dist']),
new HtmlWebpackPlugin({
title: 'webpack_demo'
})
],
module: {
rules: [
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
},
{
test: /\.(png|svg|jpg|gif)$/,
use: [
'file-loader'
]
}
]
}
}; //修改src/index.js ===================================================
import _ from 'lodash'; //引入lodash模块
import "./index.css"; // index.css
import Icon from './icon.jpg'; // 图片
import printMe from "./print.js" // printJS function component() {
var element = document.createElement('div'); //创建一个元素 element.innerHTML = _.join(['loadsh', 'webpack'], ' '); // lodash中_.join方法
var myIcon = new Image(); //创建一个图片
myIcon.src = Icon; //src赋值 element.appendChild(myIcon); //追加图片 var btn = document.createElement('button'); //创建按钮
btn.innerHTML = 'Click me and check the console!'; //内容赋值
btn.onclick = printMe; //添加事件
element.appendChild(btn); //追加元素 return element;
} document.body.appendChild(component()); //追加元素到body中 //修改src/print.js ==========================================
export default function printMe() {
console.log('from print.js');
}

npm run build 会发现基本webpack的配置之后 ,有点模样(意思)了 打开页面index.html正常访问

3.本地开发

npm install --save-dev webpack-dev-server "webpack-dev-server" 为你提供了一个简单的 web 服务器,并且能够实时重新加载

 //修改webpack.config.js
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const webpack = require('webpack'); module.exports = {
entry: {
app: './src/index.js'
},
output: {
filename: '[name].bundle.js',
path: path.resolve(__dirname, 'dist')
},
devServer: {
contentBase: './dist'
},
plugins: [
new CleanWebpackPlugin(['dist']),
new HtmlWebpackPlugin({
title: 'webpack_demo'
})
],
module: {
rules: [
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
},
{
test: /\.(png|svg|jpg|gif)$/,
use: [
'file-loader'
]
}
]
}
};
//修改package.json
...
"scripts": {
"test": "echo \"Error: no test specified\" &amp;&amp; exit 1",
"start": "webpack-dev-server --open", //start命令
"build": "webpack"
},
...

npm run start 本地起了8080端口的服务,你也可以看到自己的页面

4.热更新

//修改webpack.config.js
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const webpack = require('webpack'); module.exports = {
entry: {
app: './src/index.js'
},
output: {
filename: '[name].bundle.js',
path: path.resolve(__dirname, 'dist')
},
devServer: {
contentBase: './dist',
hot: true
},
plugins: [
new CleanWebpackPlugin(['dist']),
new HtmlWebpackPlugin({
title: 'webpack_demo'
}),
new webpack.NamedModulesPlugin(),
new webpack.HotModuleReplacementPlugin()
],
module: {
rules: [
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
},
{
test: /\.(png|svg|jpg|gif)$/,
use: [
'file-loader'
]
}
]
}
};

npm run start 运行http://localhost:8080/ 然后你去修改print js的console(或者添加其他代码) 会发现命令行输出updated. Recompiling... 字样 这就是简单的实现了热更新

最后

本文只是大概从几个demo来对于webpack的基础概念 入口entry 出口 output loader plugins mode(没有直面涉及)几大模块的梳理于实践,让大家对于webpack不在那么陌生!

后续文章会从更深入的角度去学习webpack! 暂定下周1 发表文章(内容 详细介绍hot 实现一个简易的vue-cli等等)

demo的代码我会同步github

原文地址:https://segmentfault.com/a/1190000016927436

还不打算去认识一下webpack?的更多相关文章

  1. Vue.js——60分钟webpack项目模板快速入门

    概述 browserify是一个 CommonJS风格的模块管理和打包工具,上一篇我们简单地介绍了Vue.js官方基于browserify构筑的一套开发模板.webpack提供了和browserify ...

  2. Vue.js——webpack

    Vue.js——60分钟webpack项目模板快速入门 browserify是一个 CommonJS风格的模块管理和打包工具,上一篇我们简单地介绍了Vue.js官方基于browserify构筑的一套开 ...

  3. Vue.js——60分钟webpack项目模板快速入门

    概述 browserify是一个 CommonJS风格的模块管理和打包工具,上一篇我们简单地介绍了Vue.js官方基于browserify构筑的一套开发模板.webpack提供了和browserify ...

  4. Vue 入门. 如何在HTML代码里面快速使用Vue

    概述 browserify是一个 CommonJS风格的模块管理和打包工具,上一篇我们简单地介绍了Vue.js官方基于browserify构筑的一套开发模板.webpack提供了和browserify ...

  5. 我去,你竟然还不会用 synchronized

    二哥,离你上一篇我去已经过去两周时间了,这个系列还不打算更新吗?着急着看呢. 以上是读者 Jason 发来的一条信息,不看不知道,一看真的是吓一跳,上次我去是 4 月 3 号更新的,离现在一个多月了, ...

  6. 什么,你还使用 webpack?别人都在用 vite 搭建项目了

    一.vite 到底是干嘛的? vite 实际上就是一个面向现代浏览器,基于 ES module 实现了一个更轻快的项目构建打包工具. vite 是法语中轻快的意思. vite 的特点: 1.轻快的冷服 ...

  7. Webpack概念

    webpack概念 我经常用 webpack,打算做一次比较详细的概念清点和梳理.从 0 配置 webpack,由于 webpack5(2019.07.27)暂时还没有发布.并且从Webpack Mi ...

  8. r.js结合gulp等于webpack(angular为例)

    本人大学时玩dojo,开始了AMD模块化的不归路,工作后一直使用requirejs,感觉非常好.但是,近来随着react的火热,webpack成为了天下无敌的模块化工具,能做模块化,合并压缩,监视等, ...

  9. 细说 webpack 之流程篇

    摘自: http://taobaofed.org/blog/2016/09/09/webpack-flow/ 引言 目前,几乎所有业务的开发构建都会用到 webpack .的确,作为模块加载和打包神器 ...

随机推荐

  1. phoenixframe自己主动化測试平台对div弹出框(如弹出的div登陆框)的处理

    package org.phoenix.cases; import java.util.LinkedList; import org.phoenix.action.WebElementActionPr ...

  2. 【POJ 2248】 Addition Chain

    [题目链接] http://poj.org/problem?id=2248 [算法] 搜索剪枝 剪枝1 : 优化搜索顺序,从大到小枚举 剪枝2 : Ai + Aj可能相等,只需搜一次即可 剪枝3 : ...

  3. 【POJ 3740】 Easy Finding

    [题目链接] http://poj.org/problem?id=3740 [算法] Dancing Links算法解精确覆盖问题 详见这篇文章 : https://www.cnblogs.com/g ...

  4. Coursera Algorithms Programming Assignment 2: Deque and Randomized Queue (100分)

    作业原文:http://coursera.cs.princeton.edu/algs4/assignments/queues.html 这次作业与第一周作业相比,稍微简单一些.有三个编程练习:双端队列 ...

  5. C Looooops(扩展欧几里得+模线性方程)

    http://poj.org/problem?id=2115 题意:给出A,B,C和k(k表示变量是在k位机下的无符号整数),判断循环次数,不能终止输出"FOREVER". 即转化 ...

  6. 0505 php-数组、控制语句、函数

    数 组 (定义.使用.赋值.遍历.分类.冒泡排序) 1.数组包括元素.下标.数组长度 2.php中的数组长度用$len = count("$数组名"); 3.定义一个数组:$arr ...

  7. Django day16 Auth组件

    一:Auth组件 -django内置的用户认证系统,可以快速的实现,登录,注销,修改密码... -怎么用? (1)先创建超级用户: -python3 manage.py createsuperuser ...

  8. Electron桌面应用:环境搭建

    目录 一.简介 二.市场 三.安装 1.安装node版本 2.安装国内的npm包管理器 3.安装electron 4.验证electron否安装成功 5.使用git克隆一个electron简单的项目, ...

  9. SQLyog 快捷方式

    连接Ctrl+M 创建新连接Ctrl+N 以当前连接属性创建新连接Ctrl+F4/Ctrl+W 断开当前连接Ctrl+Tab 切换到下一个连接Ctrl+Shift+Tab 切换到上一个连接Ctrl+1 ...

  10. [BZOJ1821][JSOI2010]部落划分

    感觉学了这么久还是有那么一丢丢进步的...上个学期看到这道题,虽然早就学过并查集和二分了但还是一点思路都没有,现在可以秒切了呢 思路就是二分+并查集,有些人说是生成树,其实它没有变成树,只是运用了生成 ...