简介:
webpack:是近期最火的一款模块加载器兼打包工具,它能把各种资源,例如JS(含JSX)、coffee、样式(含less/sass)、图片等都作为模块来使用和处理。
react:现在最热门的前端框架,毫无疑问是 React 。
es2015:ECMAScript 6。
以上是她们的基本定义,想想能将她们结合在一起开发我们的项目是多么的激动人心啊。当然在正式开发之前我们也有很多准备工作需要做好,这也可能是对新手最棘手的问题。下面我们就直接进入正题吧。
环境搭建:
-
首选我们需下载安装Node.js,下载地址:https://nodejs.org/en/ (注意:为了能支持es2015请下载4.0以上版本)
-
安装了node之后我们还需要npm也就是包管理器,当然新的node已经集成了npm的。所以此步骤可以跳过了
-
有了npm后,win+r然后输入cmd打开,然后输入命令:
-
npm install webpack -g
执行命令后我的webpack就全局安装好了,这里提醒一下,在项目文件中我们还需要将webpack写入package.json(局部安装)
项目创建:
-
在D盘创建我们的项目文件“reactPro”,目录结构如下:
-
在cmd中定位项目地址,执行命令:
-
cd D:\reactPro
-
D:
定位完成后,我们利用npm生成package.json文件,执行命令:
-
npm init
-
上面命令执行完成之后我们就生成了一个node项目,接下来就可以安装我们的node模块了
首选安装webpack,执行命令:
-
npm install webpack --save-dev
然后安装webpack需要的加载器,执行命令:
-
npm install babel-loader babel-preset-es2015 babel-preset-react --save-dev
- 加载器这里应该是很重要的一步了,如果没有这几个加载器我们的jsx语法,和es2015语法就会报错(ps:网上很多教程都没有重点提及这几个加载器)
- 好了有了这几个重要的加载器来编译我们的代码之后,我们还要安装react模块,这样才能开发我们react应用。安装react输入如下命令:
-
npm install react react-dom --save-dev
文件配置&运行:
- 前面我们已经创建好了我们的项目文件也安装完了必要的模块,环境已经搭建好了,现在就是万事具备只欠东风啦。
- 接下来,我们开始配置webpack开发的webpack.config.js文件配置,通过配置这个文件我们告诉webpack如何编译我们的代码,话不多说直接上代码:
-
var path = require('path'); var webpack = require('webpack'); module.exports = { entry: ['webpack/hot/dev-server', path.resolve(__dirname, './app/main.js')], output: { path: path.resolve(__dirname, './build'), filename: 'bundle.js' }, module: { loaders: [ { test: /\.js?$/, exclude: /(node_modules|bower_components)/, loader: 'babel', query: { presets: ['es2015', 'react'] } } ] }, plugins: [ new webpack.HotModuleReplacementPlugin() ] };
- 大家可能发现了‘webpack/hot/dev-server‘这句话,没错这就是我们的webpack-dev-server,她允许我们可以把本地项目跑在像nginx那样的web服务器上,更重要的是我们可以在package.json文件内定义scripts,同时修改webpack的配置文件来达到类似BrowserSync(即文件修改能被监听,并自动刷新浏览器)的效果!
- 安装webpack-dev-server执行:
-
npm install webpack-dev-server --save-dev
- 在package.json文件中为scripts添加:
-
"scripts": { "build": "webpack", "dev": "webpack-dev-server --devtool eval --progress --colors --content-base build" }
- 最后我们的package.json代码是这样的:
{ "name": "reactpro1", "version": "1.0.0", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1", "bundle": "babel-node tools/run bundle", "build": "webpack", "dev": "webpack-dev-server --devtool eval --progress --colors --content-base build" }, "author": "jx", "license": "ISC", "devDependencies": { "babel-core": "^6.8.0", "babel-loader": "^6.2.4", "babel-preset-es2015": "^6.6.0", "babel-preset-react": "^6.5.0", "react": "^15.0.2", "react-dom": "^15.1.0", "webpack": "^1.13.0", "webpack-dev-server": "^1.14.1" }, "dependencies": { "webpack": "^1.13.0", "webpack-dev-server": "^1.14.1" }, "description": "" }
- 这里有一点提醒大家,package.json中name不能跟我们的模块和项目文件目录同名
- index.html变成这样:
-
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>React Project</title> </head> <body> <script src="http://localhost:8080/webpack-dev-server.js"></script> <div id="content"></div> <script src="./bundle.js"></script> </body> </html>
- 最后我们这样执行(ps:这一步可以先跳过,写完我们的项目代码后再来执行):
-
npm run dev
react&es2015代码编写:
- 所有东西都齐全了,现在我们就可以开始我们的愉悦的代码编写了
- 根据webpack.config.js的配置结合我们的文件目录结构,首先是main.js:
-
let React = require('react'); let ReactDOM = require('react-dom'); let AppComponent = require('./components/productBox.js'); ReactDOM.render(<AppComponent />, document.getElementById('content'));
- 这里的let就是es2015的东西了,关于更多的如class,module之类的语法可以去这个网站学习,地址:http://es6.ruanyifeng.com/#README
- 在main.js里我们引入了'./components/productBox.js'这个模块,productBox.js代码如下:
-
var React = require('react'); var ProductBox; ProductBox = React.createClass({ render: function () { return ( <div className="productBox"> hello react&es2015&webpack! </div> ); } }); module.exports = ProductBox;
- 到这里,简单的功能代码就完成了,当运行项目后根据webpack.config.js的配置回来build目录下生成bundlie.js文件,我们只需要在build目录下的index.html文件中引入bundle.js就完成我们的整个项目测试代码了.index.html如下:
-
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>React Project</title> </head> <body> <script src="http://localhost:8080/webpack-dev-server.js"></script> <div id="content"></div> <script src="./bundle.js"></script> </body> </html>
- 代码开发完成后就要运行我们的项目了,在cmd中执行:
-
npm run dev
- 等待编译完成,打开浏览器输入http://localhost:8080/index.html
- 至此我们的测试项目大功告成!
- github项目地址:https://github.com/jx2011/webpack-react-es6.git
总结:
- 由于时间原因,这篇文章只能重点指出环境搭建和一些注意事项,一些概念性的东西并没有深入讲解,希望大家谅解,也各位大神指出错误和不足,鄙人定虚心接受。
- 最后感谢大家支持,后面如果有空,会再发表gulp雪碧图的相关教程,有兴趣可以关注一下。
来源:oschina
链接:https://my.oschina.net/u/1403181/blog/672501