分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

webpack基础

发布时间:2023-09-06 02:18责任编辑:赖小花关键词:webpack

webpack-基础
貌似这些属于编译原理的内容。
当时看了一点编译原理,当中的自动机,彻底懵。
不过大概了解了一点内容。感觉webpack一个打包工具非常类似于一个编译器,将一个文件,转换为另外一个文件。

一些概念

入口

入口,即寻找入口文件的及其依赖项的文件。即编译前的文件
配置文件为webpack.config.js中修改为

module.exports = { ??entry: "./app.js"}

使用这个可以设置入口文件为./app.js由该文件,可以寻找相关的依赖

出口

output告诉要生成那些文件

const path = require("path");module.exports = { ??entry: "./app.js", ?output: { ???filename: "my-first-webpack.js" ?}}

导出该文件

loader

loader可以让webpack处理非js文件。

 ?module: { ???rules: [ ???????{test: /\.txt$/, use: ‘raw-loader‘} // 再遇到txt文件的时候,需要使用ras-loader进行转换一下 ????] ?}

遇到txt文件的时候,需要使用raw-loader进行转换

类似于express中的中间件

raw-loader表示将文件作为字符串进行读取

插件

即打包,优化,定义环境中的变量等。

 ?plugins: [ ???new HtmlWebpackPlugin({template: ‘./src/index.html‘}) ?]

入口文件

const config = { ???entry: ‘./file.js‘, // 定义入口文件}module.exports = config;

分离应用程序和第三方库

const config = { ???entry: { ???????app: ‘./src/app.js‘, ???????vendors: ‘./src/vendors.js‘ ???}}module.exports = config;

在上方中webpack会根据app和vendors分别创建两个互相没有任何依赖的依赖图,进行打包
在平常中,一个html文档,只使用一个入口文件。

出口

如何写出编译后的文件。

const config = { ???entry: { ???????app: ‘./src/app.js‘, ???????vendors: ‘./src/vendors.js‘ ???}, ???output: { ???????filename: ‘bundle.js‘, ?// 文件名称 ???????path: ‘/home/assets‘ ???// 输出后的绝对路径 ???}}module.exports = config;
const config = { ???entry: { ???????app: ‘./src/app.js‘, ???????vendors: ‘./src/vendors.js‘ ???}, ???output: { ???????filename: ‘[name].js‘, ?// 文件名称,name为对象名,输出的文件为app.js vendors.js ???????path: ‘/home/assets‘ ???// 输出后的绝对路径 ???}}module.exports = config;

出口,即编译完成后生成的文件

load

load为代码转换,可以使用这个加载css文件,使用这个将typeScript转为JavaScript
安装

npm install --save-dev ts-loader
const config = { ???entry: { ???????app: ‘./app.js‘ ???}, ???output: { ???????filename: ‘[name].js‘, ?// 文件名称,name为对象名,输出的文件为app.js vendors.js ???????path: ‘/home/assets‘ ???// 输出后的绝对路径 ???}, ???module: { ???????rules: [ ???????????{test: /\.ts$/, use: ‘ts-loader‘} ???????] ???}}module.exports = config;

使用这个可以在打包的时候,将ts文件转为js文件。

插件

创建同名的js文件
这里的是apply()函数。

const pluginName = "ConsoleLogOnBuildWebpackPlugin"class ConsoleLogOnBuildWebpackPlugin { ???apply(){ ???????console.log(‘构建开始‘); ???}}

使用插件

const webpack = require(‘webpack‘); // 访问内置插件const config = { ???entry: { ???????app: ‘./app.js‘ ???}, ???output: { ???????filename: ‘[name].js‘, ?// 文件名称,name为对象名,输出的文件为app.js vendors.js ???????path: ‘/home/assets‘ ???// 输出后的绝对路径 ???}, ???module: { ???????rules: [ ???????????{test: /\.ts$/, use: ‘ts-loader‘} ???????] ???}, ???plugins: [ ???????new webpack.optimize.UgifyJsPlugin(), ???????new ConsoleLogOnBuildWebpackPlugin() ???]}module.exports = config;

webpack基础

原文地址:https://www.cnblogs.com/melovemingming/p/9806764.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved