本文中的例子支持webpack-dev-server自动刷新及react热替换,使用了redux管理state,用react-router切换路由,用babel实现ES6语法书写,同时支持async/await书写,eslint代码检测,及sass的使用

1.搭建前文档结构:

assets 用来存放css 及 图片等资源

components存放组件

js 用来存放js文件

页面主文件是 index.html

不用纠结文件夹结构,只要不涉及团队合作,这玩意儿就像自己的女人,想咋睡咋睡,想咋组织就咋组织 大致如此

2.webpack配置文件的书写

var webpack=require('webpack');
var path=require('path');
var DashboardPlugin = require('webpack-dashboard/plugin');//一款很屌的插件,用了你就知道了
module.exports={
entry:{ //多文件入口以及配置dev server及热替换
app:[path.resolve(__dirname, './js/index.js'),'webpack/hot/dev-server.js','webpack-dev-server/client?http://0.0.0.0:8080'],
vendor:['react']
},
output:{ //多文件输出 注意[name]这种写法
publicPath:'/build',
filename:'[name].js'
},
module:{
loaders:[ //最新loader的写法
{test:/\.js?$/,loaders:['babel','eslint'],exclude: /node_modules/},
{test:/\.jsx?$/,loaders:['babel','eslint'],exclude: /node_modules/},
{test: /\.(jpg|png|gif)$/, loader: "url?limit=8192",exclude: /node_modules/},
{test:/\.(scss|css)?$/,loader:'style!css!sass',exclude: /node_modules/}
]
},
resolve:{ //配置node_modules的地址、文件名省略及文件路径简写
root:'/Users/****/mywork/rwp/node_modules',
extensions:['','.js','.jsx','.json','.scss'],
alias:{
listCss:path.join(__dirname,'./assets/css/list'),
publicCss:path.join(__dirname,'./assets/css/public'),
bkCss:path.join(__dirname,'./assets/css/bk'),
coverCss:path.join(__dirname,'./assets/css/cover'),
listCp:path.join(__dirname,'./components/list'),
bkCp:path.join(__dirname,'./components/bk'),
cbCp:path.join(__dirname,'./components/cb'),
publicCp:path.join(__dirname,'./components/public'),
coverCp:path.join(__dirname,'./components/cover')
}
},
eslint:{//eslint配置文件
configFile:"./.eslintrc.js"
},
plugins:[
new webpack.NoErrorsPlugin(), //防错误打断程序插件
new DashboardPlugin(),
new webpack.optimize.CommonsChunkPlugin('vendor', 'vendor.js')
]
}

以上是webpack.config.js,用于生产环境的配置文件,下面这个是一个比较粗糙的生产环境配置文件,待优化

var webpack=require('webpack');
var path=require('path');
var uglifyJsPlugin = webpack.optimize.UglifyJsPlugin;//代码压缩插件
var CopyWebpackPlugin = require('copy-webpack-plugin');//文件拷贝插件
module.exports={
entry:{
"./build/app":path.resolve(__dirname, './js/index.js'),
"./build/vendor":['react']
},
output:{
publicPath:'/',
path:path.resolve(__dirname,'../../package'),
filename:'[name].js'
},
module:{
loaders:[
{test:/\.js?$/,loaders:['babel','eslint'],exclude: /node_modules/},
{test:/\.jsx?$/,loaders:['babel','eslint'],exclude: /node_modules/},
{test: /\.(jpg|png|gif)$/, loader: "url?limit=8192",exclude: /node_modules/},
{test:/\.(scss|css)?$/,loader:'style!css!sass',exclude: /node_modules/}
]
},
resolve:{
root:'/Users/****/mywork/rwp/node_modules',
extensions:['','.js','.jsx','.json','.scss'],
alias:{
listCss:path.join(__dirname,'./assets/css/list'),
publicCss:path.join(__dirname,'./assets/css/public'),
bkCss:path.join(__dirname,'./assets/css/bk'),
coverCss:path.join(__dirname,'./assets/css/cover'),
listCp:path.join(__dirname,'./components/list'),
bkCp:path.join(__dirname,'./components/bk'),
cbCp:path.join(__dirname,'./components/cb'),
publicCp:path.join(__dirname,'./components/public'),
coverCp:path.join(__dirname,'./components/cover')
}
},
plugins:[
new webpack.optimize.DedupePlugin(),//文件内容深度去重
new uglifyJsPlugin({
compress: {
warnings: false
}
}),
new CopyWebpackPlugin([
{ from: 'index.html', to: 'index.html' }
])
]
}

关于配置文件的详细叙述及各字段意思请大家查看官网:

https://webpack.github.io/docs/configuration.html#module-loaders

下面是package.json

{
"name": "rwp",
"version": "1.0.0",
"description": "this is a test project",
"main": "server.js",
"scripts": {
"build": "webpack --progress --profile --colors --config webpack.production.config.js",
"start": "webpack-dashboard -- webpack-dev-server --hot --progress --colors"
},
"keywords": [
"test"
],
"babel": {
"presets": [
"es2015",
"react"
]
},
"author": "jhone lee",
"license": "ISC",
"dependencies": {
"babel-runtime": "^6.11.6",
"body-parser": "1.15.x",
"copy-webpack-plugin": "^3.0.1",
"express": "4.x",
"jquery": ">=2.x",
"react": ">=15.2.x",
"react-redux": "^4.4.5",
"react-router": "2.6.x",
"react-router-redux": "^4.0.5",
"redux": "^3.5.2",
"redux-logger": "^2.6.1",
"redux-thunk": "^2.1.0"
},
"devDependencies": {
"babel": "6.x",
"babel-core": "6.x",
"babel-eslint": "^6.1.2",
"babel-loader": "*",
"babel-plugin-transform-runtime": "^6.12.0",
"babel-polyfill": "^6.13.0",
"babel-preset-es2015": "^6.9.0",
"babel-preset-react": "^6.11.1",
"babel-preset-stage-0": "^6.5.0",
"babel-runtime": "^6.11.6",
"css-loader": "*",
"eslint": "^3.3.1",
"eslint-loader": "^1.5.0",
"eslint-plugin-react": "^5.2.2",
"file-loader": "^0.9.0",
"jsx-loader": "^0.13.2",
"node-sass": "^3.8.0",
"react-dom": "^15.2.1",
"redux": "^3.5.2",
"redux-devtools": "^3.3.1",
"sass-loader": "^4.0.0",
"style-loader": "^0.13.1",
"url-loader": "^0.5.7",
"webpack": "1.13.1",
"webpack-dashboard": "^0.1.7",
"webpack-dev-server": "1.4.x"
}
}

这里需要注意的script里面需要执行的命令:

npm run build 会运行生产环境的config文件

npm start 会运行开发环境的config文件

后面至于 redux及react-router怎么用,以及.babelrc  和 .eslintrc怎么配置不在本文的讨论范畴

仅粘出我的 两个rc文件

module.exports = {
"parser":"babel-eslint",
"env": {
"browser": true,
"commonjs": true,
"es6": true
},
"extends": "eslint:recommended",
"parserOptions": {
"ecmaFeatures": {
"experimentalObjectRestSpread": true,
"jsx": true
},
"sourceType": "module"
},
"plugins": [
"react"
],
"rules": {
"indent": [
"warn",
4
],
"linebreak-style": [
"warn",
"unix"
],
"quotes": [
"warn",
"double"
],
"semi": [
"error",
"always"
],
"no-unused-vars":[
"warn",
{
"vars": "all",
"args": "after-used"
}
],
"no-console":[
"error",{
"allow":["log","error","warn"]
}],
"no-constant-condition":[
"warn",{
"checkLoops":false
}
],
"no-fallthrough":["warn",{
"commentPattern": "break[\\s\\w]*omitted"
}]
}
};

以上为 .eslintrc

{
"presets": [ "es2015", "stage-0","react"],
"plugins": [
["transform-runtime", {
"polyfill": false,
"regenerator": true
}]
]
}

以上为 .babelrc

至于react-router及redux怎么用,以后有时间再说

react+webpack+babel+eslint+redux+react-router+sass 环境快速搭建的更多相关文章

  1. react+webpack+babel环境搭建

    [react+webpack+babel环境搭建] 1.react官方文档推荐使用 babel-preset-react.babel-preset-es2015 两个perset. Babel官方文档 ...

  2. webpack 通用环境快速搭建

    能用babel编译es2015 . 能热编译.能加载静态资源(js/css/font/image).是一个很通用的开发环境,虽然不智能.但很好扩展 npm 安装列表: # webpack 核心 npm ...

  3. 基于webpack的Vue.js开发环境快速搭建

    1. 安装node node下载地址 2. 安装淘宝 NPM npm 是node.js 的包管理工具. 镜像命令地址 #命令行: npm install -g cnpm 3. 安装vue # 全局安装 ...

  4. Redux React & Online Video Tutorials

    Redux React & Online Video Tutorials https://scrimba.com/@xgqfrms https://scrimba.com/c/cEwvKNud ...

  5. react看这篇就够了(react+webpack+redux+reactRouter+sass)

    本帖将对一下内容进行分享: 1.webpack环境搭建: 2.如何使用react-router: 3.引入sass预编译: 4.react 性能优化方案: 5.redux结合react使用: 6.fe ...

  6. webpack,react,babel

    window搭建webpack,react,babel傻瓜教程   首先现在的webpack教程已经很多了,写这篇的原因是因为自己在从小白开始的搭建过程中,并没有找到比较好的教程,花费了很多的时间,s ...

  7. 重温 Webpack, Babel 和 React

    开始之前 在书写文章之前,我假设大家已经有了 JavaScript,Node 包管理工具,Linux 终端操作 这些基本技能,接下来,我将一步一步指引大家从头搭建一个 React 项目 最终实现的效果 ...

  8. react案例->新闻移动客户端--(react+redux+es6+webpack+es6的spa应用)

    今天分享一个react应用,应在第一篇作品中说要做一个react+redux+xxx的应用.已经做完一部分,拿出来分享.github地址为:点我就可以咯~ 这里实现了一个新闻移动站的spa.本来想写p ...

  9. 详解 Webpack+Babel+React 开发环境的搭建

    1.认识Webpack 构建应用前我们先来了解一下Webpack, Webpack是一个模块打包工具,能够把各种文件(例如:ReactJS.Babel.Coffeescript.Less/Sass等) ...

随机推荐

  1. python 基础篇 04(列表 元组 常规操作)

    本节主要内容:1. 列表2. 列表的增删改查3. 列表的嵌套4. 元组和元组嵌套5. range 一. 列表1.1 列表的介绍列表是python的基础数据类型之一 ,其他编程语言也有类似的数据类型. ...

  2. Linux服务架设篇--traceroute命令

    作用: 查看数据包在传输过程中经过了哪些IP地址的路由器.网关. 工作原理: 首先向远程主机发送TTL为1的UDP数据包,按照协议规定,路由器收到数据包,TTL值减1,这时TTL就为0,路由器就会丢弃 ...

  3. Week1 Team Homework #1 from Z.XML-项目选择思路--基于对曾经大作业项目的思考

    这两天试玩了一下去年学长的满分工程<shield star>游戏,再结合了一下他们团队的博客记录,有一种非常牛逼的感觉.具体对于这款游戏的一些思考和看法,毛大神已经说的很好了.因此,这里主 ...

  4. 【积累】LinqToSql复合查询结果转DataTable数据

    最近的项目用到了大量的复合查询结果用于数据源,绑定到数据控件上. 为了方便,我们把它转换成DataTable的数据源形式.请看下面的示例: 1)思考自己需要的数据,然后组合,因此创建一个新的类: // ...

  5. lintcode-49-字符大小写排序

    49-字符大小写排序 给定一个只包含字母的字符串,按照先小写字母后大写字母的顺序进行排序. 注意事项 小写字母或者大写字母他们之间不一定要保持在原始字符串中的相对位置. 样例 给出"abAc ...

  6. [转] const int *a与int *const a,const int *const a的区别

    http://blog.csdn.net/zhangheng837964767/article/details/33783511 关键问题点:const 属于修饰符 ,关键是看const 修饰的位置在 ...

  7. JDBC数据源的驱动问题

    classes12.jar,ojdbc14.jar,ojdbc5.jar和ojdbc6.jar的区别,之间的差异 在使用Oracle JDBC驱动时,有些问题你是不是通过替换不同版本的Oracle  ...

  8. 微信PC端授权页面提示授权入口所在域名为空

    做第三方微信平台的时候做授权页面,用window.open方法从第三方平台页面打开新的授权标签页. 在IE浏览器上出问题,提示如下: 在chrome和firefox浏览器上正常. 搜了一下,发现微信是 ...

  9. Spark程序

    Spark认识&环境搭建&运行第一个Spark程序 2017-07-09 17:17 by 牛仔裤的夏天, 181 阅读, 0 评论, 收藏, 编辑 摘要:Spark作为新一代大数据计 ...

  10. BZOJ 3668:起床困难综合症(贪心)

    分析:按位贪心即可. program sleep; var a,g:..]of longint; n,i,m,ans,t,len,x,y,v:longint; c:char; s:string; e: ...