常用的Webpack配置
官方文档:
http://webpack.github.io/docs/
1. 安装python
2. 安装node.js msi
3. npm自动打包在最新的node.js安装包里
被封的包用国内镜像下载
// 全局安装webpack
npm install webpack -g
常规项目把依赖写入package.json包中去
// 进入项目
cd myproject
// 初始化npm,生成package.json
npm init
// 写入package.json关于webpack的依赖
npm install webpack --save-dev
在项目目录新建webpack.config.js文件,并且写入:
var webpack = require('webpack');
var commonsPlugin = new webpack.optimize.CommonsChunkPlugin('common.js');
module.exports = {
// 插件项
plugins: [commonsPlugin],
// 页面入口文件配置
entry: {
index: './src/js/page/index.js',
component: './src/js/page/component.js'
},
// 入口文件输出配置
output: {
path: 'dist/js/page',
filename: '[name].js'
},
module: {
// 加载器配置
loaders: [
// .css文件使用 style-loader 和 css-loader 来处理
{ test: /\.css$/, loader: 'style-loader!css-loader' },
// .js文件使用 jsx-loader 来编译处理
{ test: /\.js$/, loader: 'jsx-loader?harmony' },
// .scss文件使用style-loader、css-loader和sass-loader来编译处理
// loader可以省略不写,多个loader之间用!连接
{ test: /\.scss$/, loader: 'style!css!sass?sourceMap' },
// 图片文件使用 url-loader 来处理,小于8kb的直接转为base64
// url-loader将样式中引用到的图片转为模块来处理,使用该加载器需要先进性安装:
// npm install url-loader --save-dev
{ test: /\.(png|jpg)$/, loader: 'url-loader?limit=8192' }
]
},
// 其他解决方案配置
resolve: {
// 从这里查找module
root: 'E:/myproject/node_modules', // 绝对路径
// 自动扩展文件后缀名,意味着我们require模块可以省略不写后缀名
extensions: ['', '.js', '.json', '.scss'],
// 模块别名定义,方便后续直接引用别名,无须多谢长长的地址
alias: {
AppStore: 'js/stores/AppStores.js', // 后续直接 require('AppStore') 即可
ActionType: 'js/actions/ActionType.js',
AppAction: 'js/actions/AppAction.js'
}
}
};
配置信息的参数“?limit=8192”表示将所有小于8kb的图片都转为base64形式
(其实应该说超过8kb的才使用 url-loader 来映射到文件,否则转为data url形式)。
// 执行webpack.config.js文件
webpack
// 压缩混淆脚本,这个非常非常重要!
webpack - p
// 安装vue框架
npm install vue --save-dev
我的webpack与vue打包实例github地址:
https://github.com/liuqiuchen/myWebpack
添加vue加载器时:
/**
* Created by user on 2016/11/17.
*/
var webpack = require('webpack');
var commonsPlugin = new webpack.optimize.CommonsChunkPlugin('common.js');
// 命令行下载关于vue加载器的模块:
// npm install extract-text-webpack-plugin --save-dev
var ExtractTextPlugin = require('extract-text-webpack-plugin');
module.exports = {
// 插件项
/**
* 使用webpack的DefinePlugin来指定生产环境,以便在压缩时可以让UglifyJS自动删除代码块内的警告语句
*/
plugins: [
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: '"production"'
}
}),
new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
})
],
// 页面入口文件配置
entry: {
index: './src/js/page/index.js',
component: './src/js/page/component.js'
},
// 入口文件输出配置
output: {
path: 'dist/js/page',
filename: '[name].js'
},
module: {
// 加载器配置
loaders: [
// .css文件使用 style-loader 和 css-loader 来处理
{ test: /\.css$/, loader: 'style-loader!css-loader' },
// .js文件使用 jsx-loader 来编译处理
{ test: /\.js$/, loader: 'jsx-loader?harmony' },
// .scss文件使用style-loader、css-loader和sass-loader来编译处理
// loader可以省略不写,多个loader之间用!连接
{ test: /\.scss$/, loader: 'style!css!sass?sourceMap' },
// 图片文件使用 url-loader 来处理,小于8kb的直接转为base64
// url-loader将样式中引用到的图片转为模块来处理,使用该加载器需要先进性安装:
// npm install url-loader --save-dev
{ test: /\.(png|jpg)$/, loader: 'url-loader?limit=8192' },
{ test: /\.vue$/, loader: 'vue' }
]
},
vue: {
// ... other vue options
loaders: {
js: 'coffee',
html: 'raw'
}
},
// 其他解决方案配置
resolve: {
// 从这里查找module
root: 'E:/myproject/node_modules', // 绝对路径
// 自动扩展文件后缀名,意味着我们require模块可以省略不写后缀名
extensions: ['', '.js', '.json', '.scss'],
// 模块别名定义,方便后续直接引用别名,无须多谢长长的地址
alias: {
AppStore: 'js/stores/AppStores.js', // 后续直接 require('AppStore') 即可
ActionType: 'js/actions/ActionType.js',
AppAction: 'js/actions/AppAction.js'
}
}
};
常用的Webpack配置的更多相关文章
- 常用的webpack 配置
const path = require('path'); let HtmlWebpackPlugin = require('html-webpack-plugin'); let VueLoaderP ...
- webpack配置命令
从2015年开始,webpack就是当前最火的构建工具.跟着时代向前走.准没错.我们要追随大神的脚步.走在前端技术栈的前列.大神等等我. 由于webpack是基于nodejs环境下的.所以先安装nod ...
- Webpack配置示例和详细说明
/* * 请使用最新版本nodejs * 默认配置,是按生产环境的要求设置,也就是使用 webpack -p 命令就可以生成正式上线版本. * 也可以使用 webpack -d -w 命令,生成用于开 ...
- webpack配置这一篇就够
最近看了一篇好文,根据这个文章重新梳理了一遍webpack打包过程,以前的一些问题也都清楚了,在这里分享一下,同时自己也做了一些小的调整 原文链接:http://www.jianshu.com/p/4 ...
- 前端工程化(二)---webpack配置
导航 前端工程化(一)---工程基础目录搭建 前端工程化(二)---webpack配置 前端工程化(三)---Vue的开发模式 前端工程化(四)---helloWord 继续上一遍的配置,本节主要记录 ...
- vue-cli中webpack配置详解
vue-cli是构建vue单页应用的脚手架,命令行输入vue init <template-name> <project-name>从而自动生成的项目模板,比较常用的模板有we ...
- webpack配置实践
首先我们的需求: 打包调试 提取公共代码 压缩 热替换 1.打包调试 第一步,我们在目标文件夹下安装webpack(假设已有package.json)npm i webpack@ -gcnpm i w ...
- 对vue中 默认的 config/index.js:配置的详细理解 -【以及webpack配置的理解】-config配置的目的都是为了服务webpack的配置,给不同的编译条件提供配置
当我们需要和后台分离部署的时候,必须配置config/index.js: 用vue-cli 自动构建的目录里面 (环境变量及其基本变量的配置) var path = require('path') ...
- webpack配置指南
Webpack已经出来很久了,相关的文章也有很多,然而比较完整的例子却不是很多,让很多新手不知如何下脚,下脚了又遍地坑 说实话,官方文档是蛮乱的,而且有些还是错的错的..很多配置问题只有爬过坑才知道 ...
随机推荐
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(80)-自由桌面
系列目录 前言 这次我们来做一个有趣的事情,有朋友跟做了很远,找我要自由桌面的代码,这次我们将演示自由桌面的代码. 自由桌面:用户可以随意增删改桌面的布局.个数(只留自己需要看到的数据),这次纯属Ea ...
- 通过 floating IP 访问 VIP - 每天5分钟玩转 OpenStack(126)
前面我们是直接用 curl 测试 VIP,在更为真实的场景中通常会使用 floating IP 访问 VIP. 下面我们给 VIP 关联一个 floating IP,再进行测试. 访问 Project ...
- 安装eclipse的maven插件
我们团队用maven来管理项目需要的库文件,其实以前都没听过maven,第一次接触这个,师兄要我直接去装下这个,开始以为还挺简单的,没想到中间遇到了一些小麻烦,现在把我成功安装maven的过程分享下, ...
- Opserver开源的服务器监控系统(ASP.NET)
Opserver是Stack Exchange下的一个开源监控系统,系统本身由C#语言开发的ASP.NET(MVC)应用程序,无需任何复杂的应用配置,入门很快.下载地址:https://github. ...
- bcp 命令实例
set sql_flow="select Id,',',ApplierName,',',FlowStatus,',',IsApproved,',',CreateTime from *** w ...
- javascript arguments(转)
什么是arguments arguments 是是JavaScript里的一个内置对象,它很古怪,也经常被人所忽视,但实际上是很重要的.所有主要的js函数库都利用了arguments对象.所以agru ...
- “此网页上的某个 Web 部件或 Web 表单控件无法显示或导入。找不到该类型,或该类型未注册为安全类型。”
自从vs装了Resharper,看见提示总是手贱的想去改掉它.于是乎手一抖,把一个 可视web部件的命名空间给改了. 喏,从LibrarySharePoint.WebPart.LibraryAddEd ...
- 08讲browse命令的使用技巧
.浏览所有parts ,使用技巧 .浏览所有 nets,使用技巧 在上图中选择nets .浏览所有 offpage connector,使用技巧 如上 .浏览所有 DRC makers,使用技巧 5. ...
- ubuntu14 查找并删除所有文件名中带有特定关键词的文件
http://askubuntu.com/questions/625219/how-to-search-and-delete-files-who-contain-specific-string-in- ...
- 学习笔记 :DrawText
最近在做一个TStringGrid的自绘处理,在画文字处理上遇到了高度的计算问题.后来经过一段时间还是找到了一些方法: 1.使用TLabel 这个方法是有点绕路的,方法倒是简单,就是使用AutoSiz ...