需求场景: 希望通过一个webpack文件夹管理多个站点的打包流程.

假设现在我要为站点domain配置打包流程.

npm 添加淘宝镜像

你懂得

vim ~/.npmrc
registry = https://registry.npm.taobao.org

Mac 启动mysql

mysql.server start

mysql -uroot -p

工程目录结构

  1. 所有站点共用的目录为cssjs, 这两个文件夹存放公共的css和js模块.
  2. 打包出来的文件输出在dist/xxx文件夹下
  3. 各个站点的webpack配置文件和入口文件放在www/xxx文件夹下.
.
├── css
│   ├── bar.css
│   ├── bar.scss
│   └── foo.scss
├── dist
│   └── domain
├── js
│   ├── bar.coffee
│   └── foo.js
├── node_modules

├── package.json
├── webpack.config.js
└── www
└── domain
├── entry.js
└── webpack.config.js

管理domain站点

命令: webpack --config www/domain/webpack.config.js

// ./www/domain/webpack.config.js

var webpack = require("webpack");
var path = require('path'); module.exports = { resolve: {
root: [
path.resolve('./css'),
path.resolve('./js'),
],
extensions: ["", ".js", ".coffee"],
}, entry: "./www/domain/entry.js", output: {
path: 'dist/domain',
publicPath: '/static/',
filename: "domain.[hash].js",
}, module: { loaders: [
{
test: /\.vue$/,
loader: 'vue',
}, {
test: /\.css$/,
loaders: ["style", "css"],
},
{
test: /\.scss$/,
loaders: ["style", "css", "sass"],
}, {
test: /\.coffee$/,
loader: "coffee-loader",
}, ], }, };

实际上, webpack.config.js文件也可以放在根目录下, 并且通过命令行向它传入一些参数

这个时候命令可以等效为:webpack --domain domain

// ./webpack.config.js
var webpack = require("webpack");
var path = require('path');
var argv = require('yargs').argv; var domain = argv.domain || 'default'; module.exports = { resolve: {
root: [
path.resolve('./css'),
path.resolve('./js'),
],
extensions: ["", ".js", ".coffee"],
}, entry: "./www/" + domain + "/entry.js", output: {
path: 'dist/' + domain,
publicPath: '/static/',
filename: domain + ".[hash].js",
}, externals: {
// "jquery": "$",
}, plugins: [
// new webpack.ProvidePlugin({$:'jquery', jQuery:'jquery'}),
], module: { // preLoaders: [
// {
// test: /\.js$/,
// loader: 'eslint',
// exclude: [/node_modules/],
// },
// ], loaders: [
{
test: /\.vue$/,
loader: 'vue',
}, {
test: /\.css$/,
loaders: ["style", "css"],
},
{
test: /\.scss$/,
loaders: ["style", "css", "sass"],
}, {
test: /\.coffee$/,
loader: "coffee-loader",
}, // {test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=application/font-woff'},
// {test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/, loader: 'file'},
// {test: /\.eot(\?v=\d+\.\d+\.\d+)?$/, loader: 'file'},
// {test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=image/svg+xml'},
], }, };

全局模块

npm install -g webpack coffee-script

本地模块

{
"name": "pack",
"version": "1.0.0",
"scripts": {
"domain": "webpack --config www/domain/webpack.config.js"
},
"devDependencies": {
"coffee-loader": "^0.7.2",
"coffee-script": "^1.11.1",
"crypto-js": "^3.1.8",
"css-loader": "^0.25.0",
"file-loader": "^0.9.0",
"node-sass": "^3.11.2",
"sass-loader": "^4.0.2",
"style-loader": "^0.13.1",
"url-loader": "^0.5.7",
"vue": "^2.0.5",
"vue-loader": "^9.8.1",
"webpack": "^1.13.3"
}
}

webpack 1.x 配合npm scripts管理多站点的更多相关文章

  1. npm scripts + webpack 实践经验(React、Nodejs)

    最近用Webpack+npm scripts+Mongodb+Nodejs+React写了个后台项目,在用Webpack构建过程中遇到了许多坑,就写出来分享一下. 构建工具五花八门,想当年刚学会Gru ...

  2. 【转】npm包管理器那些事

    原文链接:http://www.cnblogs.com/shuoer/p/7782125.html npm包管理器那些事! 今天和朋友针对npm包全局安装和本地项目安装这个梗展开的激烈的讨论,故此做一 ...

  3. windows下npm scripts不能执行的问题

    最近在学webpack为了方便把运行脚本写入package.json文件中,如下: "scripts": { "start": "webpack-de ...

  4. npm scripts 使用指南

    转载自:http://www.ruanyifeng.com/blog/2016/10/npm_scripts.html Node 开发离不开 npm,而脚本功能是 npm 最强大.最常用的功能之一. ...

  5. 谈谈npm依赖管理

    引言 现在的前端开发几乎都离不开nodejs的包管理器npm,比如前端在搭建本地开发服务以及打包编译前端代码等都会用到.在前端开发过程中,经常用到npm install来安装所需的依赖,至于其中的技术 ...

  6. nodeJS---模块与npm包管理工具

    nodeJS---模块与npm包管理工具 一:从模块外部访问另一个模块内的成员; 假如我现在还在D盘中的node文件夹内中的app.js代码改成如下: var msg = 'hello'; var f ...

  7. 我为何放弃Gulp与Grunt,转投npm scripts(上)

    本文来源于我在InfoQ中文站翻译的文章.原文地址是:http://www.infoq.com/cn/news/2016/02/gulp-grunt-npm-scripts-part1 Cory Ho ...

  8. NPM包管理器入门(附加cnpm : 无法加载文件错误解决方案)

    NPM 包管理器 1.作用: 快速构建nodejs工程 快速安装和依赖第三个模块 2.使用方法 快速构建 npm init 会得到一package.json文件 { "name": ...

  9. nrm NPM源管理工具

    nrm NPM源管理工具 工具 前端 npm cnpm 今天经过同事介绍,发现一个好玩的东西——nrm(NPM registry manager) nrm 是一个可以快速切换NPM源的node插件.由 ...

随机推荐

  1. asp.net core 六 Oracle ORM

         .netcore 中 Oracle ORM      在真正将项目移植到.netcore下,才发现会有很多问题,例如访问Oracle,问题出现的时间在2017年底          参考连接 ...

  2. 我是如何在公司项目中使用ESLint来提升代码质量的

    ESLint:你认识我吗 ESLint是一个语法规则和代码风格的检查工具. 和学习所有编程语言一样,想要入门ESLint,首先要去它的官网看看:https://eslint.org/. ESLint的 ...

  3. Asp.net Core2.0 缓存 MemoryCache 和 Redis

    自从使用Asp.net Core2.0 以来,不停摸索,查阅资料,这方面的资料是真的少,因此,在前人的基础上,摸索出了Asp.net Core2.0 缓存 MemoryCache 和 Redis的用法 ...

  4. Python系列之 - 线程基础

    一.什么是线程 线程:顾名思义,就是一条流水线工作的过程,一条流水线必须属于一个车间,一个车间的工作过程是一个进程 所以,进程只是用来把资源集中到一起(进程只是一个资源单位,或者说资源集合),而线程才 ...

  5. BOM,Dom 回顾

    加给元素: offsetLeft(距离定位父级的距离)/offsetTop(距离定位父级的距离)/offsetWidth(可视宽度)/offHeight(可视高度) clientLeft(左边框宽度) ...

  6. Python默认版本切换

    Mac上自带python2.7 版本,但是我又下了一个3.7版本(下载的版本默认安装在 /Library/Frameworks/Python.framework/Versions/3.7/bin/py ...

  7. jdk 动态代理源码分析

    闲来无事,撸撸源码 使用方法 直接看代码吧.. package com.test.demo.proxy; import java.lang.reflect.InvocationHandler; imp ...

  8. 【BZOJ3685】【zkw权值线段树】普通van Emde Boas树

    原题传送门 因为马上要开始搞树套树了,所以学了一波权值线段树...毕竟是会点zkw线段树的,所以zkw线段树大法好! 解题思路: 介绍一下权值线段树吧,其实感觉就是线段树的本义,就是你用线段树维护了数 ...

  9. hdu 5008 查找字典序第k小的子串

    Boring String Problem Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Ot ...

  10. hdu 4747 线段树

    Mex Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submis ...