webpack 学习

1.1 什么是Webpack

​ Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。

​ 从图中我们可以看出,Webpack 可以将多种静态资源 js、css、less 转换成一个静态文件,减少了页面的请求。 接下来我们简单为大家介绍 Webpack 的安装与使用

1.2 Webpack安装

全局安装

复制代码
npm install webpack -g
npm install webpack-cli -g

安装后查看版本号

复制代码
webpack -v

1.3 快速入门

13.1 JS打包

(1)创建src文件夹,创建bar.js

js 复制代码
exports.info=function(str){
   document.write(str);
}

(2)src下创建logic.js

js 复制代码
exports.add=function(a,b){
	return a+b;
}

(3)src下创建main.js

js 复制代码
var bar= require('./bar');
var logic= require('./logic');
bar.info( 'Hello world!'+ logic.add(100,200));

(4)创建配置文件webpack.config.js ,该文件与src处于同级目录

js 复制代码
var path = require("path");
module.exports = {
	entry: './src/main.js',
	output: {
		path: path.resolve(__dirname, './dist'),
		filename: 'bundle.js'
	}
};

以上代码的意思是:读取当前目录下src文件夹中的main.js(入口文件)内容,把对应的js文件打包,打包后的文件放入当前目录的dist文件夹下,打包后的js文件名为bundle.js

(5)执行编译命令

复制代码
webpack

执行后查看bundle.js 会发现里面包含了上面两个js文件的内容

(7)创建index.html ,引用bundle.js

html 复制代码
<!doctype html>
<html>
  <head>  
  </head>
  <body>   
    <script src="dist/bundle.js"></script>
  </body>
</html>

测试调用index.html,会发现有内容输出

1.3.2 CSS打包

(1)安装style-loader和 css-loader

Webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用 loader 进行转换。

Loader 可以理解为是模块和资源的转换器,它本身是一个函数,接受源文件作为参数,返回转换的结果。这样,我们就可以通过 require 来加载任何类型的模块或文件,比如 CoffeeScript、 JSX、 LESS 或图片。首先我们需要安装相关Loader插件,css-loader 是将 css 装载到 javascript;style-loader 是让 javascript 认识css

复制代码
cnpm install style-loader css-loader --save-dev

(2)修改webpack.config.js

js 复制代码
var path = require("path");
module.exports = {
	entry: './src/main.js',
	output: {
		path: path.resolve(__dirname, './dist'),
		filename: 'bundle.js'
	},
	module: {
		rules: [  
            {  
                test: /\.css$/,  
                use: ['style-loader', 'css-loader']
            }  
        ]  
	}
};

(3)在src文件夹创建css文件夹,css文件夹下创建css1

css 复制代码
body{
 background:red;
}

(4)修改main.js ,引入css1.css

复制代码
require('./css1.css');

(5)重新运行webpack

(6)运行index.html看看背景是不是变成红色啦?

相关推荐
用户4794928356915几秒前
我是怎么把模型回复用tts播放的更自然的
前端
JS_GGbond1 分钟前
前端崩溃监控:给网页戴上“生命体征监测仪”
前端
俊劫2 分钟前
AI 编码技巧篇(内部分享)
前端·javascript·ai编程
Maxkim3 分钟前
一文读懂 Chrome CRX📦:你需要了解的核心知识点
前端·前端工程化
JackJiang5 分钟前
AI大模型爆火的SSE技术到底是什么?万字长文,一篇读懂SSE!
前端·websocket
Mr_chiu5 分钟前
数据可视化大屏模板:前端开发的效率革命与架构艺术
前端
进击的野人6 分钟前
一个基于 Vue 的 GitHub 用户搜索案例
前端·vue.js·前端框架
ZsTs1196 分钟前
《2025 AI 自动化新高度:一套代码搞定 iOS、Android 双端,全平台 AutoGLM 部署实战》
前端·人工智能·全栈
命中水6 分钟前
从怀疑到离不开:我第一个由 AI 深度参与完成的真实项目复盘
前端·openai
我是ed7 分钟前
# Vue3 图片标注插件 AILabel
前端