26.webpack 入门
webpack
官方:
https://webpack.js.org/
http://webpack.github.io/
中文:
资料:
https://segmentfault.com/a/1190000006178770
学习入口:
官网----->1 中文文档-->指南
2 立即开始
安装webpack:
1、3.x
安装 cnpm i -D webpack@3.8.1
卸载 npm un -D webpack
2、4.x
安装 cnpm i -D webpack webpack-cli
局部安装验证版本:
webpack -v 错误 —— 全局安装
1、node_modules/.bin/webpack -v
2、npx webpack -v
3、工程文件 package.json
"scripts": {
"test": "webpack -v"
},
运行npm run test
webpack3 翻译器 ES6-->ES5 babel
webpack src dist
npx webpack js/index.js dist/index.bundle.js
文件不会被压缩!
webpack4 翻译器 ES6-->ES5 babel
webpack --mode=development src -o dist 正确的格式
npx webpack --mode=development js/index.js dist/index.bundle.js --->main.js
npx webpack --mode=development js/index.js --output dist/index.bundle.js
文件会被压缩!
简写:webpack --mode=development
前提条件:
1、源src 必须是 src/index.js
输出: 默认 dist/main.js
配置文件: webpack.config.js
执行:webpack
指定执行某一个具体的文件: 必须带上 --config
webpack --config webpack.dev.config.js
loader:处理资源 从右往左进行处理
cnpm i -D style-loader css-loader
css-loader:加载css文件
style-loader:处理样式 页面生成style标签
sass:
cnpm i -D sass-loader node-sass
less:
cnpm i -D less-loader less
cnpm i -D url-loader file-loader
file-loader:处理文件 单纯的把文件复制到目标路径 重命名
url-loader 依赖 file-loader :把文件转成base64
exp:
module.exports = {
mode:"development",
entry:"./src/index.js", //引入模块 ./
output:{
path:`${__dirname}/dist/`, //必须是一个绝对路径
filename:"index.bundle.js"
},
module: {
rules: [
{
test: /\.css$/,
use: ['style-loader','css-loader']
},
//sass
{
test: /\.scss$/,
use: ['style-loader','css-loader','sass-loader']
},
//less
{
test: /\.less$/,
use: ['style-loader','css-loader','less-loader']
},
{
test: /\.(png|jp(e)?g|gif)$/,
use: ["url-loader"]
}
]
}
}
model:{ 模块、包
rules:[ //规则
{test:/正则/,use:[xxxx-loader]} use:使用什么
loader进行处理
]
}
indes.js
import $ from "jquery";
import "./asset/1.css";
import img from "./asset/111.jpg"
$(function(){
$("#div1").click(function(){
//$(this).addClass("active");
// alert(img);
$(this).css({
width:"330px",
height:"495px",
background:`url(${img})`
});
});
});
res:


生成页面 index.html
cnpm i -D html-webpack-plugin
new HtmlWebpackPlugin()
new HtmlWebpackPlugin({
//title: 'My App',
template: 'public/index.html',用户模板文件
filename: 'index.html', 生成的页面 可以不写 默认就是index.html
hash:true 防止js/css缓存
})
ExtractTextWebpackPlugin 在 webpack4中被废弃 替换者 mini-css-extract-plugin
cnpm i -D mini-css-extract-plugin
mini-css-extract-plugin++应用场景只在开发阶段++!
++在生产阶段换成 style++
--watch 简写 -w 实时编译 问题 不能主动刷新页面
webpack-dev-server 服务器
不能实时编译,可以实时刷新页面
cnpm i -D webpack-dev-server
webpack.config.js
const webpack = require('webpack');
const path = require("path");
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
// webpack --mode=development src/index.js --output dist/main.js
module.exports = {
mode:"development",
entry:"./src/index.js",//模块 ./
output:{
path:path.resolve(__dirname,"dist"),//绝对路径
filename:"main.js"
},
devServer: {
contentBase: "./dist", //资源目录 www/public
index: 'main.js',
host:"localhost",
port:9000,
open:true,// --open
hot: true,
compress: true, //gzip压缩
// proxy: {
// '/api': {
// target: 'https://other-server.example.com',
// secure: false
// }
// }
},
module: {
rules: [
// { test: /\.css$/, use: ["style-loader","css-loader"] },
{
test: /\.css$/,
use: [
MiniCssExtractPlugin.loader,
"css-loader"
]
},
{ test: /\.(png|jp(e)?g|gif|svg|icon)$/,use: ["file-loader"] },
]
},
plugins: [
new webpack.NamedModulesPlugin(),
new webpack.HotModuleReplacementPlugin(),
new webpack.BannerPlugin('版权所有,翻版必究'),
//new HtmlWebpackPlugin()
new HtmlWebpackPlugin({
template: 'public/index.html',
filename: 'index.html',
hash:true
}),
new MiniCssExtractPlugin({
filename: "[name].css",
chunkFilename: "[id].css"
})
]
}
css/url/file/babel/vue-loader
css分离(mini-css-extract-plugin)
HtmlWebpackPlugin
HtmlWebpackPlugin —— Clean...
babel
26.webpack 入门的更多相关文章
- Webpack 入门指南 - 3. Hello, Angular2!
Webpack 入门指南 - 1.安装 Webpack 入门指南 - 2.模块 这一次,我们使用 Webpack 来打包 Angular 2 的应用. 与官方的 Hello, Angular 2 项目 ...
- webpack入门(2)
webpack入门(2) ps:每个案例都是基于前一个案例改造的 webpack入门(1) 戳这里 案例源码戳这里 十二.ProvidePlugin 自动加载模块 new webpack.Provid ...
- 【一小时入门】webpack 入门指南
什么是 webpack? webpack是近期最火的一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX).coffee.样式(含less/sass).图片等都作为模块来使用和处理. 我们可以 ...
- webpack入门(1)
webpack入门(1) 源码戳这里 ps:每个案例对应相应的demo,例如"案例1"对应"demo1" 一.webpack基本功能及简单案例 安装webpac ...
- webpack入门教程之Hello webpack(一)
webpack入门教程系列为官网Tutorials的个人译文,旨在给予想要学习webpack的小伙伴一个另外的途径.如有不当之处,请大家指出. 看完入门教程系列后,你将会学习到如下内容: 1.如何安装 ...
- webpack入门——webpack的安装与使用
一.简介 1.什么是webpack webpack是近期最火的一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX).coffee.样式(含less/sass).图片等都作为模块来使用和处理. ...
- 一小时包教会 —— webpack 入门指南
什么是 webpack? webpack是近期最火的一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX).coffee.样式(含less/sass).图片等都作为模块来使用和处理. 我们可以 ...
- Webpack 入门指南 - 2.模块
这一次我们谈谈模块问题. 通常我们希望这个项目可以分为多个独立的模块,比如,上一次提高的 hello 函数,如果我们定义为一个模块,其它模块引用之后,直接调用就好了.在前端怎么使用模块呢?这可说来话长 ...
- Webpack 入门指南 - 1.安装
Webpack 是目前流行的打包工具,如何安装它呢? 1. 安装 Node Js 首先,Webpack 是基于 NodeJs 的工具,你必须首先安装 NodeJs. NodeJs 仅仅只需要在你的系统 ...
随机推荐
- ASP.NET C# 实现钉钉签名算法
在 https://open-doc.dingtalk.com/microapp/faquestions/hxs5v9 钉钉给出了JAVA/PHP算法,下面是C#算法 using System.Sec ...
- 面向对象编程技术的总结和理解(c++)
目录树 1.继承 1.1 基类成员在派生类中的访问属性 1.2继承时导致的二义性 1.3 多基继承 2.虚函数的多态 2.1虚函数的定义 2.2派生类中可以根据需要对虚函数进行重定义 2.3 虚函数的 ...
- go微服务框架go-micro深度学习(五) stream 调用过程详解
上一篇写了一下rpc调用过程的实现方式,简单来说就是服务端把实现了接口的结构体对象进行反射,抽取方法,签名,保存,客户端调用的时候go-micro封请求数据,服务端接收到请求时,找到需要调用调 ...
- 【C++】C++中assert和ENDEGU预处理语句
assert 断言语句是C++中的一种预处理宏语句,它能在程序运行时根据否定条件中断程序. C++中的assert()函数可以实现断言功能,在使用assert函数之前应该先引入<cassert& ...
- Python分页组件
分页组件的实现: class Pagination(object): """ 自定义分页 """ def __init__(self,cur ...
- SpringBoot里使用RMI进行远程方法调用
一.Java RMI定义 Java RMI:Java远程方法调用,即Java RMI(Java Remote Method Invocation)是Java编程语言里,一种用于实现远程过程调用的应用程 ...
- [elk]kafka_elk
kafka https://www.tutorialspoint.com/apache_kafka/apache_kafka_cluster_architecture.htm https://dzon ...
- 【基础篇】elasticsearch之索引模板Template[转]
一,模板简述:template大致分成setting和mappings两部分:索引可使用预定义的模板进行创建,这个模板称作Index templates.模板设置包括settings和mappings ...
- ffmpeg中AVBuffer的实现分析
[时间:2017-10] [状态:Open] [关键词:ffmpeg,avutil,avbuffer, 引用计数] 0 引言 AVBuffer是ffmpeg提供的基于引用计数的智能指针的一个实现版本. ...
- Js 动态添加的数据,监听事件监听不到
在开发中遇到这种问题,就是有些数据,比如按钮是动态添加进去的,结果添加事件监听无效,直接写死在页面上是可以的. 这就是很明显的加载先后顺序的问题了. 解决的方法: $(document).ready( ...


