web项目下怎么跳转到另一个HTML文件,3.webpack自动生成项目中的HTML文件

1. webpack中的CommonJS和ES Mudule 规范

1.1 CommonJs规范

CommonJs规范的出发点:JS没有模块系统、标准库较少、缺乏包管理工具;为了让JS可以在任何地方运行,以达到Java、PHP这些后台语言具备开发大型应用的能力。

在CommonJs规范中:

一个文件就是一个模块,拥有单独的作用域;

普通方式定义的变量、函数、对象都属于该模块内;

通过require来加载模块;

通过exports和modul.exports来暴露模块中的内容;

1.2 ES Mudule 规范

ES6在语言标准的层面上,实现了模块功能,基本特点如下:

每一个模块只加载一次, 每一个JS只执行一次, 如果下次再去加载同目录下同文件,直接从内存中读取;

每一个模块内声明的变量都是局部变量, 不会污染全局作用域;

模块内部的变量或者函数可以通过export导出;

一个模块可以导入别的模块;

模块功能主要由两个命令构成:export和import;export命令用于规定模块的对外接口,import命令用于输入其他模块提供的功能:

// esm.js

let firstName = 'Jack';

let lastName = 'Wang';

export {firstName, lastName}

// export命令除了输出变量,还可以输出函数

export function (a, b) {

return a + b

}

使用export命令定义了模块的对外接口以后,其他 JS 文件就可以通过import命令加载这个模块,import命令接受一对大括号,里面指定要从其他模块导入的变量名,大括号里面的变量名,必须与被导入模块对外接口的名称相同。

// main.js

import {firstName, lastName} from './esm';

function say() {

console.log('Hello , ' + firstName + ' ' + lastName)

}

1.3 使用

现在,在src目录下新建 sum.js 和 minus.js

// sum.js ES Mudule 规范

// export default命令,为模块指定默认输出

export default function (a, b) {

return a + b

}

// minus.js commonJS 规范

module.exports = function (a, b) {

return a - b

}

修改 main.js

import sum from './sum'

import minus from './minus'

console.log('sum(1, 2): ' + sum(1, 2))

console.log('minus(5, 2): ' + minus(5, 2))

执行 npm run build 之后,打开 index.html,在控制台中可以看到输出的结果。

sum(1, 2): 3

minus(5, 2): 3

2. 自动生成项目中的HTML文件

我们为了演示打包好的 main.bundle.js ,在根目录下创建了一个 index.html ,并引入main.bundle.js。而在实际项目中,我们可以通过 webpack 的一个插件:HtmlWebpackPlugin 来自动生成HTML文件并引入我们打包好的JS和CSS文件。

安装:

npm install --save-dev html-webpack-plugin

整理项目目录:

在根目录创建config文件夹,把webpack.config.js移入config,并修改webpack.config.js:

const path = require('path')

const HtmlWebpackPlugin = require('html-webpack-plugin')

const config = {

mode: 'none',

entry: {

main: path.join(__dirname, '../src/main.js')

},

output: {

filename: '[name].bundle.js',

path: path.join(__dirname, '../dist')

},

plugins: [

new HtmlWebpackPlugin({

template: path.join(__dirname, '../index.html'),

inject: true,

minify: {

removeComments: true

}

})

]

}

module.exports = config

template:模版文件的路径,这里使用根目录下的index.html文件;

inject:设为 true 表示把JS文件注入到body结尾,CSS文件注入到head中;

minify:removeComments: true 表示删除模版文件中的注释,minify还有很多配置可选请自行参阅;

在package.json修改

"build": "webpack --config config/webpack.config.js --progress --colors"

chunks

chunks主要用于多入口文件,当你有多个入口文件,那就回编译后生成多个打包后的文件,那么chunks 就能选择你要使用那些js文件

entry: {

index: path.resolve(__dirname, './src/index.js'),

devor: path.resolve(__dirname, './src/devor.js'),

main: path.resolve(__dirname, './src/main.js')

}

plugins: [

new httpWebpackPlugin({

chunks: ['index','main']

})

]

那么编译后:

而如果没有指定 chunks 选项,默认会全部引用。

html-webpack-plugin插件的使用,在单页应用程序和多页应用程序中的 webpack配置没什么区别

new HtmlWebpackPlugin({

filename: 'index.html',

template: path.join(__dirname, '../index.html'),

inject: true,

minify: {

removeComments: true

},

hash: true

}),

new HtmlWebpackPlugin({

filename: 'demo.html',

template: path.join(__dirname, '../demo.html'),

inject: true,

minify: {

removeComments: true

},

hash: true

})

下一步注释掉index.html 中我们手动引入的 script :

Title

执行 npm run build ,可以看到,dist 目录下多了一个 index.html,这就是通过 HtmlWebpackPlugin 生成的文件,打开dist/index.html,已经自动引入了 main.bundle.js并且注释已被删除。

至此,我们已经成功实现自动生成项目中的HTML文件了。

3. 清理/dist文件夹

每次执行npm run build 打包时,都会有上次的代码遗留下来,导致我们的 /dist 文件夹相当杂乱。通常,在每次构建前清理 /dist 文件夹,是比较推荐的做法。

clean-webpack-plugin 是一个比较普及的管理插件,让我们安装和配置下:

npm install clean-webpack-plugin --save-dev

在webpack.config.js 中使用:

const { CleanWebpackPlugin } = require('clean-webpack-plugin');

在 plugins 中加入:

new CleanWebpackPlugin()

执行 npm run build ,在命令行中可见:

Hash: b1c0f8a003a675692c97

dist 文件夹已被删除了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值