Webpack是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle

概要

从 webpack v4.0.0 开始,可以不用引入一个配置文件。然而,webpack 仍然还是高度可配置的。在开始前你需要先理解四个核心概念

  • 入口(entry)
  • 输出(output)
  • loader
  • 插件(plugins)

本文分五个部分:安装,创建项目,配置文件,开发文件以及问题汇总

一、安装

  在安装Webpack前,本地需要支持node.js,从官网上下载LTS版本,然后按照步骤安装下载,其中有默认安装地址,我选择了自定义安装地址。这是菜鸟教程里的步骤,可以供参考:http://www.runoob.com/nodejs/nodejs-install-setup.html

  由于 npm 安装速度慢,本教程使用了淘宝的镜像及其命令 cnpm,安装使用介绍参照:使用淘宝 NPM 镜像

  使用语句:npm install cnpm -g --registry=https://registry.npm.taobao.org

  接着全局安装webpack

  cnpm install webpack -g / npm install webpack -g

  由于现在安装的是4.0的版本,所以还要加装一个CLI : cnpm install webpack-cli -g / npm install webpack-cli -g

  此处可能会出现一个问题:'NODE' 不是内部或外部命令,也不是可运行的程序 或批处理文件(问题1)‘webpack'不是内部或外部命令,也不是可运行的程序 或批处理文件(问题2)

二、创建项目 

  1、cmd打开,一般打开默认C盘,这是要 cd\  再  d:    然后 打开你的文件  cd webpack_demo    (如果没有还未创建,可以使用 mkdir webpack_demo && cd webpack_demo )

  

  2、初始化npm

    npm init

  3、本地安装webpack

    npm install webpack webpack-cli --save-dev

  4、安装loader

  Webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用   loader 进行转换。所以如果我们需要在应用中添加 css 文件,就需要使用到 css-loader 和 style-loader,他们做两件不同的事情,css-loader 会遍历 CSS 文件,然后找到 url() 表达式然后处理他们,style-loader 会把原来的 CSS 代码插入页面中的一个 style 标签中。

  接下来我们使用以下命令来安装 css-loader 和 style-loader(全局安装需要参数 -g)。

    npm install css-loader style-loader  

  4、创建runoob1.js,runoob2.js,index.html,style.css,

    

    

    

       

  5、打包文件 webpack runoob1.js -o bundle.js

          

  6、直接打开index.html

  

  权限问题错误:npm ERR! Error: EPERM: operation not permitted, open 'D:\webpack_demo\package.json'(问题3)

  打包问题报错webpack runoob1.js bundle.js(问题4)

 三、配置文件

  插件在 webpack 的配置信息 plugins 选项中指定,用于完成一些 loader 不能完成的工。安装一个plugin,可以自动快速的帮我们生成HTML。

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

  在 webpack 4 中,可以无须任何配置使用,然而大多数项目会需要很复杂的设置,这就是为什么 webpack 仍然要支持 配置文件。这比在终端(terminal)中手动输入大量命令要高效的多,所以创建 webpack.config.js 文件,代码如下所示:

  1. const path = require('path');
  2. var HtmlwebpackPlugin = require('html-webpack-plugin');
  3. module.exports = {
  4. mode:'production',
  5. entry: './runoob1.js',
  6. output: {
  7. path: path.resolve(__dirname, 'dist'),
  8. filename: 'bundle.js'
  9. },
  10. devServer: {
  11. historyApiFallback: true,
  12. hot: true,
  13. inline: true,
  14. progress: true,
  15. },
  16. module: {
  17. rules: [
  18. {
  19. test: /\.css$/,
  20. use: [
  21. { loader: 'style-loader' },
  22. {
  23. loader: 'css-loader',
  24. options: {
  25. modules: true
  26. }
  27. }
  28. ]
  29. }
  30. ]
  31. },
  32. plugins: [
  33. new HtmlwebpackPlugin({
  34. title: 'Hello World app'
  35. })
  36. ]
  37.  
  38. };

  接下来执行webpack命令,即可生成:

  

  你会发现多出来一个dist文件夹,直接点开里面的html文件,可以查看到结果

  可能问题:1、ERROR in Entry module not found: Error: Can't resolve 'runoob1.js' in 'D:\webpack_demo'  2、Invalid configuration object. Webpack has been initialised using a configuration object that does not match the API schema.(问题5)

四、开发环境

  在菜鸟教程中,有好几种协助开发,这里使用了webpack-dev-server开发服务,通过 localhost:8080 启动一个 express 静态资源 web 服务器,并且会以监听模式自动运行 webpack,

  全局安装  npm install webpack-dev-server -g

  在package.json 中

  1. "scripts": {
  2. "start": "webpack-dev-server --hot --inline"
  3. },

  webpack.config.js中

  1. devServer: {
  2. historyApiFallback: true,
  3. hot: true,
  4. inline: true,
  5. progress: true,
  6. },

  运行npm start ,然后在浏览器打开 http://localhost:8080/ 输出结果如下:

  

 五、问题汇总:

  (1)'NODE' 不是内部或外部命令,也不是可运行的程序 或批处理文件

    解决:设置path

  

  (2)‘webpack'不是内部或外部命令,也不是可运行的程序 或批处理文件

    解决:由于安装的是全局安装,所以webpack地址未在本地安装的文件中,要使用添加path,path中添加全局安装webpack的地址

    

  (3)权限问题错误:npm ERR! Error: EPERM: operation not permitted, open 'D:\webpack_demo\package.json'

    解决:设置为管理员权限,或者直接使用win+x,选择命令提示符(管理员),在里面运行命令就好了

  (4)打包问题报错webpack runoob1.js bundle.js

    解决:webpack4版本问题:使用本语句打包即可  webpack demo.js -o demo.bundle.js

  (5)ERROR in Entry module not found: Error: Can't resolve 'runoob1.js' in 'D:\webpack_demo'  2、Invalid configuration object. Webpack has been initialised using a configuration object that does not match the API schema.

    解决:初始化npm init,因为菜鸟教程中的配置是在3.0版本,版本4中的中改变,所以要做对应修改。使用官网内容时,引号内容要做相应调整。

参考列表:

1、菜鸟教程http://www.runoob.com/w3cnote/webpack-tutorial.html

2、webpack官网 https://www.webpackjs.com/concepts/loaders/

3、其他问题搜索例如:https://zhuanlan.zhihu.com/p/20367175?columnSlug=FrontendMagazine

Webpack指南(一):安装,创建项目,配置文件,开发环境以及问题汇总的更多相关文章

  1. vue- Vue-Cli脚手架工具安装 -创建项目-页面开发流程-组件生命周期- -03

    目录 Vue-Cli 项目环境搭建 与 python 基础环境对比 环境搭建 创建启动 vue 项目 命令创建项目(步骤小多) 启动 vue 项目(命令行方式) 启动 vue 项目(pycharm 方 ...

  2. webpack项目在开发环境中使用静态css文件

    webpack项目在开发环境中使用静态css文件 在webpack项目(本人使用的 vue-cli-webpack )中,需要引入 css 或 scss等样式文件时,本人目前知道的,通常有以下几种方法 ...

  3. Angular4.x 安装|创建项目|目录结构|创建组件

    Angular4.x 安装|创建项目|目录结构|创建组件 安装最新版本的 nodejs node.js 官网:https://nodejs.org/zh-cn/ 去官网下载 node.js,下一步下一 ...

  4. VS2017离线安装与Oracle数据库开发环境搭建

    记得之前使用VS2015打开老的MVC4项目,不能右键创建控制器和添加视图,让我非常不习惯!找遍了网络无果,最后只能回到VS2013,但我就是不喜欢用旧的VS,这是不是病... 1.将VS2017离线 ...

  5. 安装Nginx+Lua+OpenResty开发环境配置全过程实例

    安装Nginx+Lua+OpenResty开发环境配置全过程实例 OpenResty由Nginx核心加很多第三方模块组成,默认集成了Lua开发环境,使得Nginx可以作为一个Web Server使用. ...

  6. Webpack笔记(二)——搭建React开发环境

    前几天一直在学习webpack,总算比之前学习的时候有了点收获,所以在昨天发布了一篇webpack入门笔记,今天继续使用webpack练了练手,搭建了一个React开发环境,如果还不熟悉的童鞋可以看一 ...

  7. maven(多个模块)项目 部署 开发环境 问题处理历程【异常Name jdbc is not bound in this Context 异常java.lang.NoSuchMethodE】

    maven(多个模块)项目 部署 开发环境 问题处理历程[异常Name jdbc is not bound in this Context 异常java.lang.NoSuchMethodE] 201 ...

  8. 开源项目renren-fast开发环境部署(后端部分)

    开源项目renren-fast开发环境部署(后端部分) 说明:renren-fast是一个开源的基于springboot的前后端分离手脚架,当前版本是3.0 开发文档需要付费,官方的开发环境部署介绍相 ...

  9. Unix/Linux环境C编程入门教程(6) 安装Fedora C/C++开发环境

    安装Fedora  C/C++开发环境 1 Fedora 是一个开放的.创新的.前瞻性的操作系统和平台,基于 Linux. 2.选择自定义配置 3.设置版本为10.0 4.选择稍后安装 5.选择64位 ...

  10. 在windows下使用多版本Python安装相应的虚拟开发环境

    在windows下面使用多版本Python安装相应的虚拟开发环境   在搭建一个项目的时候,希望使用最新版的Python3.7版本,但是Python3.6的版本也要留下,那么问题来了,如何解决这个问题 ...

随机推荐

  1. PHP蜘蛛爬虫开发文档

    <我用爬虫一天时间“偷了”知乎一百万用户,只为证明PHP是世界上最好的语言 >所使用的程序框架 编写PHP网络爬虫, 需要具备以下技能: 爬虫采用PHP编写 从网页中抽取数据需要用XPat ...

  2. [剑指Offer] 14.链表中倒数第k个结点

    [思路]利用两个相隔为k-1个结点的指针进行遍历,当后一个指针移到末尾时,前一个指针就是要求的结点. /* struct ListNode { int val; struct ListNode *ne ...

  3. 简单配置 Tomcat 的 Server.xml(war包发布)

    <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" ...

  4. 【bzoj1465/bzoj1045】糖果传递 数论

    题目描述 老师准备了一堆糖果, 恰好n个小朋友可以分到数目一样多的糖果. 老师要n个小朋友去拿糖果, 然后围着圆桌坐好, 第1个小朋友的左边是第n个小朋友, 其他第i个小朋友左边是第i-1个小朋友. ...

  5. P2730 魔板 Magic Squares

    题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都有一种颜色.这8种颜 ...

  6. thymeleaf支持java8的日期实例

    一.实体 @Entity public class Customer { @Id @GenericGenerator(name="generator",strategy = &qu ...

  7. [Leetcode] Add two numbers 两数之和

    You are given two linked lists representing two non-negative numbers. The digits are stored in rever ...

  8. 【可持久化线段树?!】rope史上最全详解

    https://www.luogu.org/problemnew/show/P3919 看到上面链接中的题时,我在学会可持久化线段树的同时,第一次学会了一个非常屌(cai)的STL大法——rope!! ...

  9. PushState+Ajax 完美实现无刷新

    转载自:http://lazynight.me/1897.html 折腾一下PJAX,利用HTML5的新API,实现历史记录的完美导入. 不知道你用没用过Github,里边的目录跳转就是用html5的 ...

  10. JavaScript中Array(数组)的属性和方法(转)

    数组有四种定义的方式 使用构造函数:var a = new Array();var b = new Array(8);var c = new Array("first", &quo ...