webpack二(以webpack4.x起步)

一.基本安装

首先我们要创建一个目录,初始化npm,以及在本地安装webpack:复制代码
mkdir webpackapp && cd webpackapp复制代码
npm init -y复制代码
npm install --save-dev webapck复制代码
现在我们看一下我们创建的目录以及目录下的结构复制代码

二.简单实用webpack

我们先全局安装webpack: npm install -g webpack复制代码
此时,我们可以执行命令:webpack -v来查看webpack的版本号。复制代码
我们在根目录下新建一个文件:hello.js,并在其中输入代码。复制代码
function hello(str) { alert(str); } hello('hello world!');复制代码
这时,我们在命令行中输入:复制代码
webpack hello.js bundle.js复制代码
然而,预期的结果和想象的不一样:复制代码
The CLI moved into a separate package: webpack-cli Would you like to install webpack-cli? (That will run npm install -D webpack-cli) (yes/NO)复制代码
复制代码
The CLI moved into a separate package:webpack-cli. Please install 'webpack-cli' in addition to webpack itself to use the CLI. ->when using npm: npm install webpack-cli -D ->when using yarn: yarn add webpack-cli -D复制代码
报出这两种任意一种的结果的意思是什么呢? 翻译成中文: CLI(命令行工具)已经转移到了一个单独的包webpack-cli中。 除了webpack自身外,请额外安装webpack-cli来使用CLI。 -> 使用npm安装:npm install webpack-cli -D ->使用yarn安装:yarn add webpack-cli -D复制代码
也就是说,在以前的webpack版本中CLI(命令行工具)是存在于webpack中的,而现在呢,它自己独立出来了,单独地放在一个单独webpack-cli包中。所以呢,现在想要使用CLI(命令行工具)就必须安装webpack-cli才行。复制代码
安装webpack-cli:复制代码
npm install webpack-cli -D复制代码
再次运行:复制代码
webpack hello.js bundle.js复制代码
发现还是报出:复制代码
The CLI moved into a separate package: webpack-cli Would you like to install webpack-cli? (That will run npm install -D webpack-cli) (yes/NO)复制代码
这时,我们就要全局安装webpack-cli:复制代码
npm install webpack-cli -g复制代码
现在,我们再试一下。复制代码
webpack hello.js bundle.js复制代码
结果又出现了新情况:复制代码
WARNING in configuration The 'mode' option has not been set, webpack will fallback to 'production' for this value. Set 'mode' option to 'development' or 'production' to enable defaults for each environment. You can also set it to 'none' to disable any default behavior. Learn more: https://webpack.js.org/concepts/mode/ ERROR in multi ./hello.js bundle.js Module not found: Error: Can't resolve 'bundle.js' in 'C:\Users\Administrator\Desktop\webpackapp' @ multi ./hello.js bundle.js复制代码
翻译成中文: 配置警告: “mode”选项尚未设置。将“mode”选项设为“development”或“production”以启用此环境的默认设置。 multi错误 ./ hello.js bundle.js 未发现模块:错误:无法解析’C:/Users/你的用户名/Desktop/webpack-test’中的bundle.js @ multi ./hello.js bundle.js复制代码
这里的提示就是告诉我们,存在的第一个问题就是没有配置webpack的mode选项,默认的有production和development两种模式可以设置,因此我们尝试设置为development模式,在命令行中输入:复制代码
webpack --mode development复制代码
我们看到进行了打包并显示了Hash、Version、Time、Build at信息,表明已经可以打包。不过,仍然有错误提示:复制代码
ERROR in Entry module not found: Error: Can't resolve './src' in 'C:\Users\Administrator\Desktop\webpackapp'复制代码
翻译成中文:复制代码
未找到入口模块发生错误:错误:无法解析:'C:\Users\Administrator\Desktop\webpackapp'复制代码
它的意思就是,表明webpack4.x是以项目根目录下的'./src'作为入口,但是我们的项目中缺乏该路径,因此我们在根目录下创建一个src文件夹,事实上,webpack4.x以'./src/index.js'作为入口,单单创建src文件夹而没有index.js文件仍然会报错,因此我们:复制代码
将hello.js移动到'./src'中,并重新命名为'index.js'.复制代码
我们在运行一次: webpack index.js bundle.js复制代码
它还会提示can.t resolve相关的错误。复制代码
这种错误的原因是:webpack4.x的打包已经不能用'webpack 文件a 文件b' 这种方式打包了,而是在命令行中直接运行'webpack --mode development'或者'webpack --mode production'这种方式来完成打包。其中,入口文件是'./src/index.js',输出路径是'./dist/main.js'。其中,src目录中的index.js文件需要我们手动的去创建,而dist目录及dist目录下的main.js文件它会自动生成。所以说呢,这种'webpack 文件a 文件b'的打包方式已经不适用了,而是改为直接运行:复制代码
webpack --mode development复制代码
复制代码
webpack --mde production复制代码
出现下面这种情况说明打包成功:复制代码
C:\Users\Administrator\Desktop\webpackapp>webpack --mode development Hash: c66758f7d1a4004b7b60 Version: webpack 4.5.0 Time: 608ms Built at: 2018-4-6 00:42:40 Asset Size Chunks Chunk Names main.js 2.88 KiB main [emitted] main Entrypoint main = main.js [./src/index.js] 65 bytes {main} [built]复制代码

不过每次都要输入这个命令,非常麻烦,我们在package.jsonscripts中加入两个成员:

"scripts": { "test": "echo \"Error: no test specified\" && exit 1", "dev":"webpack --mode development", "build":"webpack --mode production" }复制代码
以后在打包的过程中,我们只需要执行npm run dev就相当于执行webpack --mode development, 执行npm run build就相当于执行webpack --mode production复制代码
我们如果需要配置webpack指令的其他参数,只需要在webpack –mode production/development后加上其他参数即可,如: webpack --mode development --watch --progress --display-modules --colors --display-reasons复制代码
当然,这也可以写入package.json的scripts之中。复制代码
总结: 我们可以将以上探索进行整理总结,首先是注意事项: 1、webpack-cli必须要全局安装,否则不能使用webpack指令; 2、webpack也必须要全局安装,否则也不能使用webpack指令。 3、webpack4.x中webpack.config.js这样的配置文件不是必须的。 4、默认入口文件是./src/index.js,默认输出文件./dist/main.js。复制代码
配置步骤: 1、创建工程目录; 2、初始化工程目录:npm init。 3、全局安装webpack-cli。 4、全局安装webpack。 5、webpack –mode development/production进行打包,可在package.json中配置dev和build的脚本,便只需运行npm run dev/build,作用相同。 6、在webpack –mode development/production可串联设置其他参数。复制代码

今天就讲到这里吧,后续会继续更新,别忘了关注了哦!


转载于:https://juejin.im/post/5ac65a376fb9a028cc6174f3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/280696.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

阿里云中间件是什么-阿里云中间件介绍

阿里云中间件是什么?这其实是一个比较虚的概念。广义的中间件范围很广。起沟通作用的都可以认为是中间件。甚至ODBC这样的东西你也可以认为是中间件。 使用了中间件之后,以前直接连接的前台应用程序和数据库之前就多了个中间件,现在前台程序把请求发给…

C# 图片、文件等加入Project Resources

一、目的 1.编译后,只想有一个exe文件,不想外部文件引用,直接运行exe文件即可。 2.不会出现文件丢失情况。 二、操作 1.右击project ->properties->Resource,左上角选择Image(或其他类型) 2. 点击…

jfinal使用shiro注解大体流程

2019独角兽企业重金招聘Python工程师标准>>> 上一篇答题梳理了jfinal整合shiro的流程,jfinal读取shiro注解,这一篇将作为补充。 1.JFinalShiroPlugin作者为shiro的RequiresRoles,RequiresPermissions, RequiresAuthent…

chrome 快捷键取消_如何使用键盘快捷键在Chrome和Firefox中固定和取消固定选项卡...

chrome 快捷键取消If you tend to open a lot of tabs in your browser, it can become difficult to find the tabs with your most used websites. Pinning tabs in your browser moves those tabs to the left and shrinks the tabs to only show the favicon, and you can …

.NET Conf China 2022参会指南速览(内含超多福利)赶紧预约!⏰⏰⏰

12月充满惊喜各种美好节日纷至沓来似在奖励一年辛苦劳作的你12月的第一波福利.NET Conf China 承包啦立即扫码预约加入.NET年度盛宴抢12月第一波惊喜!.NET Conf China 2022 .NET Conf China 2022是面向开发人员的社区峰会,延续 .NET Conf 2022 的活动&a…

python导入模块--案例

1 导入模块 1.1 问题 本案例要求先编写一个star模块,主要要求如下: 建立工作目录 ~/bin/创建模块文件 ~/bin/star.py模块中创建pstar函数,实现打印50个星号的功能然后练习导入模块,调用模块中的函数: 在交互解释器中导…

css常用命名

常用的CSS命名 头:header 内容:content/container 尾:footer 导航:nav 侧栏:sidebar 栏目:column 页面外围控制整体佈局宽度:wrapper 左右中:left right center 登录条:l…

***关于WP的邮件无法发送问题的总结(原创)

1.用FTP打开 /wp-include/class-smtp.php ,最好是下载下来,搜索一下,查找到如下的代码: $this->smtp_conn stream_socket_client($host . ":" . $port,$errno,$errstr,$timeout,STREAM_CLIENT_CONNECT,$socket_cont…

C# 简单方式运行powershell文件/使用cmd命令运行ps1

一、目的、构想 1.C# winfrom编译的tool 运行一个powershell文件。 2.只需要运行即可,不需要返回值。 3.网上部分资料需要额外添加dll。 3.已经有cmd执行命令的函数,能否直接在cmd运行? 4.在cmd黑色窗口输入powershell 能进入powershell…

​.Net 7 AOT 彻底解析下(完结篇)

楔子:本篇是承继前面三篇文章而来,分别为:.Net 7 的 AOT 和 CLR有什么区别?.Net 7 的 R2R,Crossgen2是什么?.Net 7 的AOT原理简析通过以上三篇的基础,本篇来彻底解析下AOT这门技术的底层原理。AOT此终,不再…

cmd暂停快捷键_是否有键盘快捷键可以暂停正在运行的CMD窗口的输出?

cmd暂停快捷键When running a batch script, you may need or want to pause the output in the CMD window so that you can look things over. Is there an easy way to pause, then restart the output? Today’s SuperUser Q&A post has the answer to help with a re…

bash快捷键

Ctrl h :回退一个字符Ctrl f :光标前进一个字符Ctrl b :光标后退一个字符Ctrl w :删除光标之前的一个字符串(进入剪切板)Ctrl u :删除光标前的所有字符 (进入剪切板&#xff09…

J - 青蛙的约会(扩展欧几里得)

https://vjudge.net/contest/218366#problem/J 第一步追及公式要写对:ynk-(xmk)pL > (n-m)klpx-y 可以看出扩展欧几里得原型,这里注意扩展欧几里得求出的是任意解,非最优,要推出最小解k。 (n-m)xlygcd > (n-m)(x*(x-y)/gcd)…

C# 简单方式解压Zip文件/使用VS2019自带功能

一、目的、构想 1.直接解压zip文档。 2.网上资料不少需要外部dll。 3. 找到可以不需要外部dll方法,分享。 二、code实现 using System.IO.Compression;string filePath "c:\Server\fileList"; string zipPath "C:\Server\Download\Auto.zip&quo…

在 Docker 中使用 flannel - 每天5分钟玩转 Docker 容器技术(60)

上一节我们安装和配置了 flannel,本节在 Docker 中使用 flannel。配置 Docker 连接 flannel编辑 host1 的 Docker 配置文件 /etc/systemd/system/docker.service,设置 --bip 和 --mtu。这两个参数的值必须与 /run/flannel/subnet.env 中 FLANNEL_SUBNET …

使用.NET7和C#11打造最快的序列化程序-以MemoryPack为例

译者注本文是一篇不可多得的好文,MemoryPack 的作者 neuecc 大佬通过本文解释了他是如何将序列化程序性能提升到极致的;其中从很多方面(可变长度、字符串、集合等)解释了一些性能优化的技巧,值得每一个开发人员学习,特别是框架的开…

永不丢失照片:防弹照片备份的完整指南

There’s nothing as precious and irreplaceable as your personal photos and, with a little forethought and planning, there’s no reason to ever feel the heartbreak of losing even a single one of them to theft, broken devices, or disaster. 没有比您的个人照片…

C# 检查当前系统已安装的程序app/两种方法检测

一、目的、构思 1.检测当前系统有没有安装某个程序,如果没有就重新安装。 2.在网上找到了两种方法,可惜都找不到需要检测的app。 二、code实现 1.查找注册列表方式。要在winform的project使用,在console project 貌似找不到Microsoft.Win3…

Integer源码解析

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wangyangzhizhou/article/details/77196626 概况 Java的Integer类主要的作用就是对基本类型int进行封装,提供了一些处理int类型的方法,比如int到Strin…

MySQL InnoDB存储引擎

呵呵哒。。。 MySQL体系结构和存储引擎 首先要搞懂的是什么是数据库,什么是数据库实例。 数据库:物理操作系统文件或其他形式文件类型的集合。 实例:MySQL数据库由后台线程以及一个共享内存区组成,实例才是真正对数据库进行操作的…