当前位置: 首页 > news >正文

做网站方案站点查询

做网站方案,站点查询,重庆网红景点排名,网站做的好看的webpack学习(一)基本配置 目录 webpack学习(一)基本配置 webpack简介 五大核心配置 1.入口(entry) 2.输入(output) 3.加载器(loader) 4.插件(plugins…

webpack学习(一)基本配置

目录

webpack学习(一)基本配置

webpack简介

五大核心配置

1.入口(entry)

2.输入(output)

3.加载器(loader)

4.插件(plugins)

5.模式(model)

总体配置模版

总结


webpack简介

本质上,webpack 是一个用于现代 JavaScript 应用程序的 静态模块打包工具。当 webpack 处理应用程序时,它会在内部从一个或多个入口点构建一个 依赖图(dependency graph),然后将你项目中所需的每一个模块组合成一个或多个 bundles,它们均为静态资源,用于展示内容。

而在深入了解webpack之前,需要先对webpack的配置有一定认识

五大核心配置

1.入口(entry)

简单来说就是指示 Webpack 从哪个文件开始打包

详细来说是指示 webpack 应该使用哪个模块,来作为构建其内部依赖图的开始。进入入口起点后,webpack 会找出有哪些模块和库是入口起点(直接和间接)依赖的。

默认值是 ./src/index.js,但你可以通过在webpack.config中配置 entry 属性,来指定一个(或多个)不同的入口起点。例如:

webpack.config.js

module.exports = {// 相对路径和绝对路径都行entry: './path/to/my/entry/file.js',
};
2.输入(output)

此部分用来指示 Webpack 打包完的文件输出到哪里去,如何命名等

output 属性告诉 webpack 在哪里输出它所创建的 bundle,以及如何命名这些文件。主要输出文件的默认值是 ./dist/main.js,其他生成文件默认放置在 ./dist 文件夹中。

例:

const path = require('path');module.exports = {// 入口// 相对路径和绝对路径都行entry: './path/to/my/entry/file.js',output: {// path: 文件输出目录,必须是绝对路径// path.resolve()方法返回一个绝对路径// __dirname 当前文件的文件夹绝对路径path: path.resolve(__dirname, 'dist'), // filename: 输出文件名filename: 'my-first-webpack.bundle.js',},
};
3.加载器(loader)

webpack 只能理解 JavaScript 和 JSON 文件,这是 webpack 开箱可用的自带能力。但其他资源需要借助 loader,Webpack 才能解析。

loader的作用就是 让 webpack 能够去处理其他类型的文件,并将它们转换为有效 模块,以供应用程序使用,以及被添加到依赖图中。

在更高层面,在 webpack 的配置中,loader 有两个属性:

  1. test 属性,识别出哪些文件会被转换。
  2. use 属性,定义出在进行转换时,应该使用哪个 loader。

例:

const path = require('path');module.exports = {output: {filename: 'my-first-webpack.bundle.js',},//加载器loadermodule: {//使用正则表达式匹配文件时,不能添加引号rules: [{ test: /\.txt$/, use: 'raw-loader' }],},
};

以上配置中,对一个单独的 module 对象定义了 rules 属性,里面包含两个必须属性:test 和 use。这相当于给webpack 编译器(compiler) 传递信息

在编译器打包过程中,碰到「在 require()/import 语句中被解析为 ‘.txt’ 的路径」时,在对它打包之前,先 use(使用) raw-loader 转换一下

4.插件(plugins)

简单来说是用来扩展 Webpack 的功能,loader 用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。包括:打包优化,资源管理,注入环境变量。

所以也可以这样说:插件目的在于解决 loader无法实现的其他事

想要使用一个插件,你只需要 require() 它,然后把它添加到 plugins 数组中。多数插件可以通过选项(option)自定义。你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用 new 操作符来创建一个插件实例。

例:

const HtmlWebpackPlugin = require('html-webpack-plugin');
const webpack = require('webpack'); // 用于访问内置插件module.exports = {module: {rules: [{ test: /\.txt$/, use: 'raw-loader' }],},//html-webpack-plugin 为应用程序生成一个 HTML 文件,并自动将生成的所有 bundle 注入到此文件中。plugins: [new HtmlWebpackPlugin({ template: './src/index.html' })],
};
5.模式(model)

这部分是用来配置当前的模式是出于开发模式还是生产模式,因为开发环境和打包后要上线的环境不一样,要求也不一样,这个时候就需要根据实际需求来对两个模式进行分别配置

  • 开发模式:development
  • 生产模式:production

例:

module.exports = {mode: 'production',//生成模式
};
总体配置模版
// Node.js的核心模块,专门用来处理文件路径
const path = require("path");module.exports = {// 入口entry: "./src/main.js",// 输出output: {path: path.resolve(__dirname, "dist"),filename: "main.js",},// 加载器module: {rules: [],},// 插件plugins: [],// 模式mode: "development", 
};

总结

这部分只是对webpack配置做了个简单介绍,后续会更新各个模块的详细应用,以及常用的一些优化方案,或者了解更深一点的运行机制等等,欢迎关注!

参考

webpack官网

http://www.hkea.cn/news/604100/

相关文章:

  • 盘龙城做网站推广网站推广
  • 如何做电子书网站域名站长工具
  • 物联网平台有哪些排名优化外包公司
  • 秦皇岛汽车网站制作数字营销工具
  • 培训教育的网站怎么做东莞做网站的联系电话
  • 云南做网站的公司外贸谷歌优化
  • 网页设计学徒培训可试学巢湖seo推广
  • 让顾客心动的句子seo模拟点击软件源码
  • 设计类专业包括哪些kj6699的seo综合查询
  • 手机网站制作哪家好查关键词
  • 米拓企业网站管理系统电商培训机构排名前十
  • 做效果图有哪些网站seo点击排名
  • 网络营销推广网站收录seo推广排名平台有哪些
  • 产品经理如何看待网站开发广州软件系统开发seo推广
  • wordpress 忘记管理员如何做网站seo
  • app和网站哪个有优势淘宝关键词排名
  • wordpress该域名宁波网站seo公司
  • 建购物网站怎么建呀简单的网站建设
  • 江苏省建设教育协会网站首页百度知道合伙人答题兼职入口
  • 做优化的网站平台搭建
  • 做网站需要多久网络推广是什么专业
  • 厦门加盟网站建设线上推广营销
  • 定制网站案例seo搜索引擎优化薪酬
  • 网站制作成功后怎么使用浏览器观看b站视频的最佳设置
  • 一家专门做开网店的网站北京seo专员
  • 专业企业网站搭建服务头条权重查询
  • 去哪儿网站上做民宿需要材料免费的黄冈网站有哪些平台
  • 网站建设网现在推广什么app最挣钱
  • 嘉兴装修公司做网站安装百度到桌面
  • 电商网站特点外贸营销网站建站