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。

      以上是她们的基本定义,想想能将她们结合在一起开发我们的项目是多么的激动人心啊。当然在正式开发之前我们也有很多准备工作需要做好,这也可能是对新手最棘手的问题。下面我们就直接进入正题吧。

环境搭建:

  1. 首选我们需下载安装Node.js,下载地址:https://nodejs.org/en/ (注意:为了能支持es2015请下载4.0以上版本)

  2. 安装了node之后我们还需要npm也就是包管理器,当然新的node已经集成了npm的。所以此步骤可以跳过了

  3. 有了npm后,win+r然后输入cmd打开,然后输入命令:

  4. 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
原创粉丝点击