webpack是什么?

webpack是一个现代JavaScript应用程序的静态模块打包器(module bundler)。

为什么要使用webpack呢?

随着web技术的发展,前端开发不再仅仅是静态网页的开发,前端代码的逻辑和交互越来越复杂。

回想一下最初我们如何开发一个页面,切图、写样式、用JQuery写一写JS效果,页面开发完就能直接在浏览器里查看。我们手动编译(比如用koala编译less),手动压缩(比如用compress压缩css),手动对比代码(比如用compare对比代码)。

而现在前端开发早已进入工程化和自动化,前端自动化构建工具可以帮我们完成这些重复且繁琐的工作。webpack就是前端构建工具的优秀代表。通过webpack我们可以方便快捷地处理包括JS、CSS、png、webfonts在内的资源文件。

webpack能做哪些事情呢?

  • 代码编译:把ES6转成ES5,把less编译成css等
  • 文件优化:压缩HTML、CSS、JavaScript代码,压缩合并图片等
  • 模块合并:把多个文件合成一个文件,减少http请求
  • 自动刷新:监听本地源代码的变化,自动重新构建,刷新浏览器
  • 代码校验:在代码被提交到仓库前校验代码是否符合规范
  • 自动发布:自动构建出线上发布代码并传输给发布系统

webpack如何实现这些功能呢?

webpack的核心概念:

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

入口(entry):

指示webpack应该使用哪个模块,来做为构建其内部依赖图的开始。Webpack从入口开始递归解析出所有依赖的模块。

输出(output):

告诉webpack在哪里输出它所创建的bundles,以及如何命名这些文件,默认值是 ./dist。

备注:webpack配置是标准的Node.js CommonJS模块。path是Node.js 的核心模块,用于操作文件路径。

loader:

loader让webpack能够去处理那些非JavaScript文件(webpack自身只理解JavaScript)。loader 可以将所有类型的文件转换为 webpack 能够处理的有效模块,然后你就可以利用 webpack 的打包能力,对它们进行处理。

在webpack的配置中loader有两个目标:

  • test 属性:用于标识出应该被对应的loader进行转换的某个或某些文件。
  • use 属性:表示进行转换时,应该使用哪个loader。

插件(plugins):

loader被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。

想要使用一个插件,你只需要require()它,然后把它添加到 plugins 数组中。

配置webpack

一、安装webpack

全局安装 webpack 和 webpack-cli

npm i webpack webpack-cli -g

新建项目文件夹,初始化 webpack

npm init -y  #生成package.json文件,默认所有配置

npm i webpack webpack-cli -D  #在devDependencies环境中安装

备注:webpack4.0中webpack和webpack-cli已经拆分,需要单独安装

 

二、配置webpack

根目录下新建webpack.config.js文件(也可是使用其他文件名,但需要额外配置)。

设置入口和输出

const path = require('path')

const webpack = require('webpack')

module.exports = {

entry: './src/index.js',

output: {

path: path.resolve(__dirname, 'dist'),

filename: '[name].js'

}

}

三、常见文件的配置

Html在webpack中的配置

在开发环境中安装插件

npm i html-webpack-plugin

在webpack.config.js中引入插件

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

在module.exports中配置插件

plugins: [

new HtmlWebpackPlugin({

file: 'index.html',

template: 'src/index.html'

})

]

CSS在webpack中的配置

在开发环境中安装loader

npm i css-loader less less-loader style-loader

在开发环境中安装插件

npm i mini-css-extract-plugin -D

在webpack.config.js中引入插件

const MiniCssExtractPlugin = require('mini-css-extract-plugin')

在module.exports中配置loader

module: {

rules: [{

test: /\.(css|less|sass|sty)$/,

use: [

MiniCssExtractPlugin.loader,

"css-loader",

"less-loader"

]

}]

}

在module.exports中配置插件

plugins: [

new MiniCssExtractPlugin({

filename: '[name].[chunkhash:8].css',

chunkFilename: '[id].css'

})

]

JS在webpack中的配置

根目录下新建.babelrc文件,简单配置下

{ "presets": ["env"] }

在开发环境中安装babel

npm i babel-core babel-loader babel-preset-env -D

在webpack.config.js文件里配置babel

module: {

rules: [{

test: /\.js$/,

include: [

path.resolve(__dirname, 'src')

],

use: 'babel-loader'

}]

}

图片资源在webpack中的配置

在开发环境中安装loader

npm i file-loader -D

在module.exports中配置loader

module: {

rules: [{

test: /\.(png|jpg|gif)$/,

use: [{

loader: 'file-loader'

}]

}]

}

别名@在webpack中的配置

在module.exports中配置

resolve: {

extensions: [".js", ".json", ".jsx", ".less", ".css"],

alias: {

utils: path.resolve(__dirname, 'src/utils')

}

}

npm run build

在package.json中定义脚本

"scripts": {

"build": "webpack --mode production"

}

执行npm run build脚本会启动webpack打包文件

npm run start

在package.json中定义脚本

"scripts": {

"start": "webpack-dev-server --mode development"

}

在module.exports中配置dev-server

devServer: {

port: '8080',

before(app) {

app.get('/api/test.json', (req, res) => {

res.json({

code: 200,

message: 'Hello World'

})

})

}

}

npm run start 在webpack里创建了一个node进程。

vue提供的webpack模板

vue-cli 是 Vue.js 的脚手架工具

安装

npm install -g vue-cli

用法

vue init <template-name> <project-name>

例如:vue init webpack my-project

vue官方示例:配置一个vue+webpack项目

第一步:全局安装vue-cli

npm install -g vue-cli

第二步:初始化一个基于webpack模块的新项目

vue init webpack my-project

第三步:安装依赖

cd my-project #进入新项目文件夹

npm install #安装依赖

第四部:启动项目

npm run dev

参考资料:

https://www.webpackjs.com/concepts/

https://www.webpackjs.com/guides/getting-started/

webpack 4 简单介绍的更多相关文章

  1. webpack入门篇--1.简单介绍

    简单介绍: webpack是一个模块打包工具,给js准备的打包工具,可以把很多的模块打包成很少的文件 目标: 1.切分依赖数,分到不同代码块里,按需加载,懒加 载 2.任何静态资源都可以被视为一个模块 ...

  2. client高性能组件化框架React简单介绍、特点、环境搭建及经常使用语法

    [本文源址:http://blog.csdn.net/q1056843325/article/details/54729657 转载请加入该地址] 明天就是除夕了 预祝大家新春快乐 [ ]~( ̄▽ ̄) ...

  3. 总结Vue第一天:简单介绍、基本常用知识、辅助函数

    总结Vue第一天:简单介绍.基本常用知识.辅助函数 中文官网:https://cn.vuejs.org/v2/guide/syntax.html 遇到不熟悉的可以先看一下官网,然后再看一下一些别人写的 ...

  4. 使用webstorm+webpack构建简单入门级“HelloWorld”的应用&&引用jquery来实现alert

    使用webstorm+webpack构建简单入门级"HelloWorld"的应用&&构建使用jquery来实现 1.首先你自己把webstorm安装完成. 请参考这 ...

  5. [原创]关于mybatis中一级缓存和二级缓存的简单介绍

    关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...

  6. 利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍

    一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...

  7. 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍

    一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...

  8. yii2的权限管理系统RBAC简单介绍

    这里有几个概念 权限: 指用户是否可以执行哪些操作,如:编辑.发布.查看回帖 角色 比如:VIP用户组, 高级会员组,中级会员组,初级会员组 VIP用户组:发帖.回帖.删帖.浏览权限 高级会员组:发帖 ...

  9. angular1.x的简单介绍(二)

    首先还是要强调一下DI,DI(Denpendency Injection)伸手获得,主要解决模块间的耦合关系.那么模块是又什么组成的呢?在我看来,模块的最小单位是类,多个类的组合就是模块.关于在根模块 ...

随机推荐

  1. ABP入门系列(3)——领域层定义仓储并实现

    ABP入门系列目录--学习Abp框架之实操演练 一.先来介绍下仓储 仓储(Repository): 仓储用来操作数据库进行数据存取.仓储接口在领域层定义,而仓储的实现类应该写在基础设施层. 在ABP中 ...

  2. [Swift]LeetCode250.计数相同值子树的个数 $ Count Univalue Subtrees

    Given a binary tree, count the number of uni-value subtrees. A Uni-value subtree means all nodes of ...

  3. Java面试题中的Redis大合集,所有你想找的都在这里!

    概述 Redis 是一个开源的,基于内存的结构化数据存储媒介,可以作为数据库.缓存服务或消息服务使用.``` Redis 支持多种数据结构,包括字符串.哈希表.链表.集合.有序集合.位图.Hyperl ...

  4. 我的.gitignore下配置。存在这里一下。日后有空研究研究!

    .DS_Storenode_modules/dist/yxxt/npm-debug.log*yarn-debug.log*yarn-error.log* # Editor directories an ...

  5. Java如何在运行时识别类型信息?

    在日常的学习工作当中,有一些知识是我们在读书的时候就能够习得:但有一些知识不是的,需要在实践的时候才能得到真知——这或许就是王阳明提倡的“知行合一”. 在Java中,并不是所有的类型信息都能在编译阶段 ...

  6. css3的动画特效--元素旋转(transition,animation)

    开发中,视觉要你实现一个元素的旋转问题,比如说如下图所示: 思路:首先动画动效肯定离不开anmimation动画. 和transition动画一样,animation动画也是CSS3动画的一种,这类动 ...

  7. 记Javascript一道题的理解

    代码如下: function Foo(){ getName = function(){ console.log("1"); } return this; } Foo.getName ...

  8. linux安装字体方法

    1.查看系统中文字体 #fc-list :lang=zh 2.如果提示commont not fount 说明为安装fontconfig 3.安装fontconfig #yum -y install ...

  9. Java 多线程(三)—— 线程的生命周期及方法

    这篇博客介绍线程的生命周期. 线程是一个动态执行的过程,它也有从创建到死亡的过程. 线程的几种状态 在 Thread 类中,有一个枚举内部类: 上面的信息以图片表示如下: 第一张图: 第二张图:把等待 ...

  10. 《你必须知道的.NET》读书实践:一个基于OO的万能加载器的实现

    此篇已收录至<你必须知道的.Net>读书笔记目录贴,点击访问该目录可以获取更多内容. 一.关于万能加载器 简而言之,就是孝顺的小王想开发一个万能程序,可以一键式打开常见的计算机资料,例如: ...