插件整理

extract-text-webpack-plugin

用于将css/less/sass等文件单独打包

https://webpack.docschina.org/plugins/extract-text-webpack-plugin/#src/components/Sidebar/Sidebar.jsx

1.引入

2.配置loader

style-loader用于为css包一层Js,以插入到html中,这里不用。

3.定义插件

打包好的css即为styles.css

vue-loader

https://vue-loader.vuejs.org/guide/#manual-configuration

 

cross-env

用于跨平台设置环境变量,比如process.env.NDOE_ENV,以根据不同的值进行不同的配置

https://www.npmjs.com/package/cross-env

1.安装:npm i cross-env --save-dev

2.package.json脚本中配置命令:

相当于:通过cross-env设置proccess.env.NODE_ENV为development,并运行webpack命令。

webpack.DefinePlugin

用于在业务代码中,和在webpack编译过程中,设置全局变量;

vue、react等包括好几个版本(比如开发版本会包含很多错误提示等),webpack根据这些变量名确定该打包哪个版本。

https://webpack.docschina.org/plugins/define-plugin/

注意:cross-env是设置node运行环境中的process对象,但在业务代码中(比如main.js)无发判断这个值,

这个插件将这个值配置到业务代码的全局环境中。

1.引入webpack

2.配置插件

stylus-loader

用于编写stylus格式css(相应于less/sass)

1.安装stylus-loader

2.配置

{
  test: /\.styl/,
  use: ["style-loader","css-loader",
  "stylus-loader"]
},

autoprefixer

用于自动添加css前缀,不用写-webkit-/-moz-等一大串。

postcss-loader用于对翻译好的css进行优化,通过一些插件完成,autoprefixer就是其中一个。

1.创建postcss.config.js并配置:

2.

babel-loader

处理vue中的jsx格式

1.下载babel-core/babel-loader/babel-preset-env/babel-plugin-transform-vue-jsx

2.配置babel,创建.babelrc

3.配置webpack.config.js

optimization.splitChunks

用于分离第三方库

 

rimraf

用于删除目录的工具包

注意:直接在cmd命令行执行:

rimraf dist

提示rimraf不识别,需要在package.json中配置命令并通过npm run ***执行

 

babel-preset-stage-1

用于识别es6等更高级语法,或还在草案中的语法,比如对象扩展符号...

1.npm install babel-preset-stage-1 --save-dev

2..babelrc文件中presets数组中添加"stage-1"

vue-server-renderer

vue服务端渲染必需的插件,生成独立的json,用于配置复杂的逻辑。正因有这个插件,vue的服务端渲染比react容易

 

koa-router

kou中间件,帮助koa处理路由信息

 

axios

用于应用向服务端发送请求

 

memory-fs

和node中的fs基本相同,唯一区别:对于读取的文件,node中的fs存到磁盘上,memory-fs存到内存

 

optimize-css-assets-webpack-plugin

用于压缩extract-text-webpack-plugin生成的css文件

1.引入

2.配置

cross-env NODE_ENV=development webpack-dev-server --config webpack.config.js

命令对应的开发环境下配置:

不设置hot:true,会是页面整体更新,已经写进去的数据也会没有,

设置后,只是有改动的模块更新。

webpack学习笔记 ——篇2的更多相关文章

  1. webpack学习笔记(二)-- 初学者常见问题及解决方法

    这篇文章是webpack学习第二篇,主要罗列了本人在实际操作中遇到的一些问题及其解决方法,仅供参考,欢迎提出不同意见. 注:本文假设读者已有webpack方面相关知识,故文中涉及到的专有名词不做另外解 ...

  2. 【原】webpack学习笔记

    之前在react的项目中有用过webpack,不过没有认真的去研究,这段时间又重新好好的学习一下webpack,发觉 webpack是一个很强大的东西.而且很好用,方便,接下来主要是做一下学习的笔记 ...

  3. 更博不能忘——webpack学习笔记

    webpack是前端构建系统就像grunt和gulp(之前有学习过grunt所以也就大概明白webpack是个什么东西),所以说前端技术大部分还真是相通的,现在觉得当时多看的东西并不白费,虽然长时间不 ...

  4. webpack学习笔记一:安装webpack、webpack-dev-server、内存加载js和html文件、loader处理非js文件

    一 .webpack学习环境准备: 1:window系统 2:安装node.js  官方网址 下载好后下一步下一步安装即可 安装步骤略过....... 3:nrm的安装 打开cmd命令控制台 输入:n ...

  5. Webpack学习笔记九 webpack优化总结

    webpack 优化笔记 webpack4 自带的优化包括 swingTree(摇摆树)和作用域提升 swingTree 比如入口文件 index.js引入通用方法 util, 里面有 10个方法, ...

  6. Webpack学习笔记一:What is webpack

      #,Loaders干嘛的,webpack can only process JavaScript natively, but loaders are used to transform other ...

  7. webpack学习笔记—webpack安装、基本配置

    文章结构: 什么是webpack? 安装webpack 'webpack基本配置 一.什么是webpack? 在学习react时发现大部分文章都是react和webpack结合使用的,所以在学reac ...

  8. 【webpack学习笔记(一)】流行的前端模块化工具webpack初探

    从开发文件到生产文件   有一天我突然意识到一个问题,在使用react框架搭建应用时,我使用到了sass/less,JSX模版以及ES6的语法在编辑器下进行开发,使用这些写法是可以提高开发的效率.可是 ...

  9. webpack学习笔记——sourcemap(使用webpack打包的项目如何调试代码)

    [webpack]devtool里的7种SourceMap模式是什么鬼? 里面详细介绍了7种模式的区别,和建议使用. webpack sourcemap 选项多种模式的一些解释 两篇文章大同小异,第一 ...

随机推荐

  1. 4 - BFS & Topological Algorithm

    615. Course Schedule https://www.lintcode.com/problem/course-schedule/description?_from=ladder&& ...

  2. SSM框架完成Ajax简单用户登录验证

    一.前端JSP <%@ page contentType="text/html;charset=UTF-8" language="java" %> ...

  3. Rails6新增rails db:system:change更换数据库

    rails db:system:change --to=postgresql rails db:system:change --to=mysql rails db:system:change --to ...

  4. 现代 PHP 新特性 —— 生成器入门(转)

    原文链接:blog.phpzendo.com PHP 在 5.5 版本中引入了「生成器(Generator)」特性,不过这个特性并没有引起人们的注意.在官方的 从 PHP 5.4.x 迁移到 PHP ...

  5. php(二)使用thinkphp搭建项目

    1.创建项目根目录,配置虚拟主机 1.1.创建项目根目录phpDemo01,将thinkphp_3.2.3_full.zip压缩包中ThinkPHP文件夹复制到项目根目录phpDemo01中. 1.2 ...

  6. MySQLdb使用

    介绍: mysqldb是python操作mysql数据库的一个库.mysql的几乎所有的操作都可以实现.   基本使用: import MySQLdb conn = MySQLdb.connect(h ...

  7. python 做接口自动化测试框架设计

    1,明确什么叫自动化测试,什么叫接口自动化测试,如何设计接口测试用例,已登录为例 自动化测试:解放人力来自动完成规定的测试. 自动化测试分层模型:UI层,不论WEB端还是移动端,都是基于页面元素的识别 ...

  8. IE10打印预览无反应

    1. 建议您打开IE后,按Alt键,选择”工具“-”兼容性视图设置“,将网站添加到兼容性视图列表中,看情况如何.2.internet选项-高级-启用保护模式 勾去掉 看看行不行3.按下“Windows ...

  9. keras神经网络做简单的回归问题

    咸鱼了半个多月了,要干点正经事了. 最近在帮老师用神经网络做多变量非线性的回归问题,没有什么心得,但是也要写个博文当个日记. 该回归问题是四个输入,一个输出.自己并不清楚这几个变量有什么关系,因为是跟 ...

  10. ElasticSearch踩坑记录

    一.分词错误 [2018-02-06 14:28:30:098] --- [INFO] --- [CjhArticleSimilarityTask.java:66] --- [[SimilarityC ...