webpack+react+es2015轻松环境搭建,配置,运行项目
来源:互联网 发布:查看php源码 编辑:程序博客网 时间:2024/06/05 15:15
摘要: webpack的模块化,react的组件化,以及es2015的各种新特性都很吸引人,如何将他们联合起来写出让人身心愉悦的项目代码,这是本文的中心。 本文手把手教新手搭建环境创建项目,可能有的概念描述的不清楚,但绝对是能轻松运行起来的(ps:网上大多数教程都是偏概念的,经常按着教程走到后来还是运行不起来项目或者不支持es6的语法【ps:加载器的问题】等,但真正对新手困难的还是环境的搭建和配置,本人也是入了很多坑才明白~~)
简介:
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
0 0
- webpack+react+es2015轻松环境搭建,配置,运行项目
- webpack & react项目搭建一:环境
- 基于React+webpack的项目环境搭建
- webPack+react 环境搭建
- websorm环境下,react+webpack搭建项目环境
- webstorm环境下,react+webpack+nodejs搭建项目环境
- react + webpack + ES6 环境搭建
- WEBPACK+REACT开发环境搭建
- 搭建 react+webpack开发环境
- 快速搭建 webpack + react 环境
- express+webpack+react搭建项目
- React + webpack 快速搭建项目
- webpack入门+react环境配置
- webpack入门+react环境配置
- React+Webpack开发环境配置
- webpack+react+es6环境配置
- webpack 配置 react 开发环境
- React+Webpack开发环境配置
- MySql避免重复插入记录方法(ignore,Replace,ON DUPLICATE KEY UPDATE)
- java.lang.IllegalArgumentException: No view found for id
- c++ 计算cpu占用率
- android点击Back键不退出程序,在后台运行
- 第一行代码(第二版)之定制自己的日志控制工具
- webpack+react+es2015轻松环境搭建,配置,运行项目
- android 5.0预制APK方法,android5.0预制apk
- Android WebView 简单使用
- echarts动态加载折线图数据demo
- IOS NetworkExtension 框架使用笔记
- NodeJs+Egret制作socket在线五子棋游戏(2)
- notebook.1
- 如何将应用打包成.ipa文件【转】
- 我的第一个Android应用程序(Hello world)