目前webpack已经到了3.X版本,为了方便通过最新版本打包整个前端应用,现在开始对webpack操作进行简单介绍。

  一、webpack安装

  在安装webpack之前需要注意,webpack是通过npm进行安装的,而npm存在于node.js中,类似于redhat系统的yum,都是包管理工具,只不过npm是前端框架安装管理工具而已,在安装npm需要安装node.js

  1、登录node.js官网:

    https://nodejs.org/zh-cn/

  2、在官网选择TLS稳定版本进行安装,如果是mac系统可以通过自身的brew工具,直接进行安装(brew install nodejs)

  3、在安装完毕后,直接输入nodejs -v和npm -v如果有输出值,说明安装完毕

  3.1、npm安装完毕后,自己创建一个文件夹my-web,今日该文件夹后执行 npm init --yes(或者-y)初始化一个package.json的文件,这个文件里会包含如下信息

{
"name": "vue-loader-demo",
"version": "1.0.0",
"description": "",
"main": "main.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"dev": "webpack-dev-server --inline --hot"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies": {}, #如果是--save会出现在这个{}内
"devDependencies": { #如果是--save-dev会出现这个{}内
"babel": "^6.23.0",
"babel-cli": "^6.26.0",
"babel-core": "^6.26.0",
"babel-plugin-transform-runtime": "^6.23.0",
"babel-preset-env": "^1.6.1",
"babel-preset-es2015": "^6.24.1",
"babel-runtime": "^6.26.0",
"css-loader": "^0.28.7",
"style-loader": "^0.19.0",
"vue-hot-reload-api": "^2.2.3",
"vue-html-loader": "^1.2.4",
"vue-loader": "^13.5.0",
"vue-style-loader": "^3.0.3",
"vue-template-compiler": "^2.5.3"
}
}

  4、安装完毕后,由于npm在国外,所以可以通过安装国内的淘宝cnpm加快安装速度

    登录到https://npm.taobao.org/

    找到安装步骤里的安装执行命令,在终端执行:

    npm install -g cnpm --registry=https://registry.npm.taobao.org

  5、 安装完毕后,webpack可以通过cnpm命令进行安装

  6、执行cnpm install webpack --save(--save表示永久存在,在生产环境需要,--save-dev表示在开发环境中存在)

  执行完毕后,webpack安装完毕

  

  二、webpack文件说明

    webpack文件为webpack.config.js文件,格式如下:

const path = require('path')  //定义path
module.exports={
entry:{
one:'./src/one.js' //入口文件
},
output:{
path: path.resolve(__dirname, 'dist'), //这个是node.js中引入绝对路径的命令
filename: 'output.js' //webpack执行后的出口文件
},
module:{ },
plugins:[],
devServer:{},
}

  在3.X时候可以定义多个入口与出口文件

const path = require('path')  //定义path
module.exports={
entry:{
one:'./src/one.js', //入口文件
two:'./src/two.js'
},
output:{
path: path.resolve(__dirname, 'dist'), //这个是node.js中引入绝对路径的命令
filename: '[name].js' //webpack执行后的出口文件,【name】表示和每一个对应入口文件
},
module:{ },
plugins:[],
devServer:{},
}

  

  三、webpack-dev-server

  3.X开始webpack-dev-server无需单独下载,只需要下载webpack后就会跟着自动下载,同时在webpack.config.js文件中填写配置,还可以实现热更新

const path = require('path')  //定义path
module.exports={
entry:{
one:'./src/one.js', //入口文件
two:'./src/two.js'
},
output:{
path: path.resolve(__dirname, 'dist'), //这个是node.js中引入绝对路径的命令
filename: '[name].js', //webpack执行后的出口文件,【name】表示和每一个对应入口文件
publicPath: '/temp/' //把临时修改都更新到temp目录下,这个目录是不建立的,是虚拟在内存中的目录
},
module:{ },
devServer:{//配置dev-server
contentBase: path.resolve(__dirname, './'),
host: '192.168.2.104',
compress:true,//HTML5压缩
port:9000
},
}

  如果感觉在终端敲webpack-dev-server很麻烦,可以在package.json文件中将它写在scripts下,然后执行npm run server就直接运行了

{
"name": "webpack3learn",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"server": "webpack-dev-server"//在这里增加这个命令,可以简化敲命令的长度
},
"keywords": [],
"author": "",
"license": "ISC"
}

  四、模块

  1、css打包

  使用css打包功能必须使用css.loader和style.loader这两个配合使用,首先登录npmjs的官网找到css-loader:

  https://www.npmjs.com/搜索css-loader

  找到相关命令,安装:

cnpm install css-loader style-loader --save-dev

  安装完毕后,查看模块填写参数,webpack.config.js中:

 module: {
rules: [
{
test: /\.css$/,
use: ['style-loader', 'css-loader']
}
]
},
const path = require('path')  //定义path
module.exports = {
entry: {
one: './src/one.js', //入口文件
two: './src/two.js'
},
output: {
path: path.resolve(__dirname, 'dist'), //这个是node.js中引入绝对路径的命令
filename: '[name].js', //webpack执行后的出口文件,【name】表示和每一个对应入口文件
publicPath: '/temp/' //把临时修改都更新到temp目录下,这个目录是不建立的,是虚拟在内存中的目录
},
module: {
rules: [
{
test: /\.css$/,
use: ['style-loader', 'css-loader']
}
]
},
devServer: {//配置dev-server
contentBase: path.resolve(__dirname, './'),
host: '192.168.2.104',
compress: true,//HTML5压缩
port: 9000
},
}

在src目录下添加one.css文件

body{
background:#666;
color:#fff;
}

webpack 3.X研究的更多相关文章

  1. 对Webpack 应用的研究-----------------引用

    对大多数 Web 应用来说,页面性能直接影响着流量.这是一个经常为我们所忽视的事实.用户长时间的等待流失的不仅仅是跳出率.转化率,还有对产品的耐心和信赖.很多时候我们没有意识到性能问题,那是因为平常开 ...

  2. 对webpack的初步研究8

    模块 编辑文档 在模块化编程中,开发人员将程序分解为称为模块的离散功能块. 每个模块的表面积小于完整程序,使验证,调试和测试变得微不足道.编写良好的模块提供了可靠的抽象和封装边界,因此每个模块在整个应 ...

  3. 对webpack的初步研究7

    Configuration 您可能已经注意到很少有webpack配置看起来完全相同.这是因为webpack的配置文件是导出对象的JavaScript文件.然后,webpack根据其定义的属性处理此对象 ...

  4. 对webpack的初步研究6

    Plugins 插件是webpack 的支柱.webpack本身构建在您在webpack配置中使用的相同插件系统上! 它们也是这样做的目的别的,一个装载机无法做到的. Anatomy webpack  ...

  5. 对webpack的初步研究5

    Loaders 加载器是应用于模块源代码的转换.它们允许您在处理import或“加载” 文件时预处理文件.因此,加载器有点像其他构建工具中的“任务”,并提供了处理前端构建步骤的强大方法.加载器可以将文 ...

  6. 对webpack的初步研究4

    Mode string module.exports = { mode: 'production' }; webpack --mode=production The following string ...

  7. 对webpack的初步研究3

    Output配置output配置选项告诉webpack如何将编译后的文件写入磁盘.请注意,虽然可以有多个entry点,但只output指定了一个配置. A filename to use for th ...

  8. 对webpack的初步研究2

    Entry Points 如“ 入门”中所述,有多种方法可以entry在webpack配置中定义属性.我们会告诉你,你的方法可以配置的entry属性,除了解释为什么它可能对你有用 Single Ent ...

  9. 对webpack的初步研究1

    一.概念: 1.webpack的核心是用于现代JavaScript应用程序的静态模块捆绑器.当webpack处理您的应用程序时,它会在内部构建一个依赖关系图,它映射您的项目所需的每个模块并生成一个或多 ...

随机推荐

  1. 剑指offer(14)链表中倒数第K个节点

    题目描述 输入一个链表,输出该链表中倒数第k个节点. 题目分析 用两个指针来跑,两个指针中间相距k-1个节点,第一个指针先跑,跑到了第k个节点时,第二个指针则是第一个节点. 这时候两个一起跑.当第一个 ...

  2. Visual Studio 2017 配置导出/导入/重置

    1.打开VS,按下面的快捷键呼出命令窗口 Ctrl+Alt+A 2.导入/导出/重置命令 Tools.ImportandExportSettings [/export:filename | /impo ...

  3. Mysql中 in or exists not exists not in区别 (网络整理)

    in 和or区别: 如果in和or所在列有索引或者主键的话,or和in没啥差别,执行计划和执行时间都几乎一样. 如果in和or所在列没有 索引的话,性能差别就很大了.在没有索引的情况下,随着in或者o ...

  4. JAVA基础知识笔记

    1.类只能用Public修饰,不能使用protected.private修饰.也可以不加修饰符,称做友好类. 2.类的实体元素包含成员变量和方法的定义,成员变量分为实例变量和类变量(static修饰的 ...

  5. Windows环境——MySQL安装及配置

    Mysql安装 下载地址:https://dev.mysql.com/downloads/mysql/ 根据个人需求,选择对应的操作系统,进行安装,本次安装的版本为5.7.24版本. 1.  安装完成 ...

  6. Linux文件结构

    /: 根目录,所有的目录.文件.设备都在/之下,/就是Linux文件系统的组织者,也是最上级的领导者. /bin: bin 就是二进制(binary)英文缩写.在一般的系统当中,都可以在这个目录下找到 ...

  7. WingIDE 常用快捷键

    Ctrl+N        新建文件 Ctrl+O   打开文件夹 Ctrl+W            关闭当前文件 Ctrl+S              保存文件 Ctrl+shif+S      ...

  8. 5种网络IO模型(有图,很清楚)

    同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?这个问题其实不同的人给出 ...

  9. nodejs基础(三)

    apache是web服务器,tomcat是应用(java)服务器 ###  开源中国  查找http中加载不同类型文件所需要的Content-type:http://tool.oschina.net/ ...

  10. express+mockjs实现模拟后台数据发送

    前言: 大多数时候,前端会和后端同时进行开发,即在我们开发完页面的时候,很可能还不能立马进入联调阶段,这个时候,为了保证我们接口的有效性和代码的功能完整,我们可能需要模拟数据. 模拟数据方法 1.通过 ...