webpack+react+es6 嵌入已有项目

前端之家收集整理的这篇文章主要介绍了webpack+react+es6 嵌入已有项目前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

1.库安装包, npm install

{
  "name": "react-es6-webpack","version": "1.0.0","description": "","main": "index.js","author": "","license": "ISC","devDependencies": {
    "babel-core": "^6.7.2","babel-loader": "^6.2.4","babel-preset-es2015": "^6.6.0","babel-preset-react": "^6.5.0","css-loader": "^0.23.1"
  },"dependencies": {
    "react": "^15.5.4","react-dom": "^15.5.4"
  }
}
2. webpack.config.js
var webpack = require("webpack");

module.exports = {
    entry : __dirname + "/main.js",output : {
        path : __dirname + "/out",filename : "index.js"
    },module:{
        loaders :[
            {
                test: /\.js$/,exclude: /node_modules/,loader: 'babel-loader',query:
                {
                    presets:['react','es2015']
                }
            }
        ]
    },externals: {
        'jquery': 'window.$','react': 'React','react-dom': 'ReactDOM'
    },}
externals的目的不想打react的库一起打到index.js.
presets可以方便的是用es6的各种特性

3.组件

import React from 'react';
import ReactDOM from 'react-dom';

class AppComponent extends React.Component {
    render() {
        var list = [];
        for(var i = 0; i < 100000; i++){
            var ele = <h1>{i+1}:{this.props.data}</h1>;
            list.push(ele)
        }
        return <div>{list}</div>;
    }
}

window.renderList = function(list){
    ReactDOM.render(
        <AppComponent data={list}/>,document.getElementById('root')
    );
};
4.html
<!DOCTYPE html>
<html lang="en">
    <head>
        <title></title>
        <Meta charset="UTF-8">
        <Meta name="viewport" content="width=device-width,initial-scale=1">
        <script src="https://cdn.bootcss.com/react/15.5.4/react.min.js"></script>
        <script src="https://cdn.bootcss.com/react/15.5.4/react-dom.min.js"></script>


    </head>
    <body>
        <div id="root" style="width: 400px;min-height:200px;float: left;">
        </div>
        <div style="float: left;">
            <button id="addBtn">添加</button>
            <button id="updateBtn">更新</button>
        </div>
        <script src="out/index.js"></script>
        <script>
            document.getElementById("addBtn").onclick = function(){
                renderList("hello react")
            };


            document.getElementById("updateBtn").onclick = function(){
                renderList("hello world")
            };
        </script>
    </body>
</html>
最后webpack编译即可

猜你在找的React相关文章