[关闭]
@brizer 2016-02-03T23:00:49.000000Z 字数 1776 阅读 1213

WebPack之与React结合


前言

之前学习了WebPack的配置和自动刷新,绑定服务器等细节。本文学习WebPack与React的结合使用。


安装react

我们接着在上次的文件夹中继续今天的学习。我们通过npm来安装react:

  1. npm install react --save


使用react

react的语法我在前面整理过,这里不再重复。

首先修改component.jsx文件:

  1. import React from 'react';
  2. export default class Hello extends React.Component {
  3. render() {
  4. return <h1>Hello world</h1>;
  5. }
  6. }

然后是main.js:

  1. import React from 'react';
  2. import Hello from './component.jsx';
  3. main();
  4. function main() {
  5. React.render(<Hello />, document.getElementById('app'));
  6. }

接下来是index.html:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8"/>
  5. </head>
  6. <body>
  7. <div id="app"></div>
  8. <script src="http://localhost:8080/webpack-dev-server.js"></script>
  9. <script src="bundle.js"></script>
  10. </body>
  11. </html>

转换JSX

我们需要Babel这个loader来将JSX转换为javascript:

  1. npm install babel-loader babel-core babel-preset-es2015 babel-preset-react --save-dev

如果我们出现了如下问题:

就说明我们缺少指定loader:babel-preset-es2015和babel-preset-react。
接下来我们修改配置文件webpack.config.js:

  1. var path = require('path');
  2. var config = {
  3. entry: path.resolve(__dirname, 'app/main.js'),
  4. output: {
  5. path: path.resolve(__dirname, 'build'),
  6. filename: 'bundle.js'
  7. },
  8. module: {
  9. loaders: [{
  10. test: /\.jsx?$/, // 用正则来匹配文件路径,这段意思是匹配 js 或者 jsx
  11. loader: 'babel?presets[]=react,presets[]=es2015' // 加载模块 "babel" 是 "babel-loader" 的缩写
  12. }]
  13. }
  14. };
  15. module.exports = config;

然后我们启用之前的命令npm run dev,就可以得到正常结果:


加载css

前面我们也学过通过WebPack来加载css,需要用到css-loader和style-loader,css-loader会遍历css文件,然后找到url()表达式然后处理他们,style-loader会把原来的css代码插入页面中的一个style标签中。

我们先通过npm下载loader:npm install css-loader style-loader --save-dev

然后我们修改webpack.config.js文件如下:

  1. var path = require('path');
  2. var config = {
  3. entry: path.resolve(__dirname, 'app/main.js'),
  4. output: {
  5. path: path.resolve(__dirname, 'build'),
  6. filename: 'bundle.js'
  7. },
  8. module: {
  9. loaders: [{
  10. test: /\.jsx?$/, // 用正则来匹配文件路径,这段意思是匹配 js 或者 jsx
  11. loader: 'babel?presets[]=react,presets[]=es2015' // 加载模块 "babel" 是 "babel-loader" 的缩写
  12. },{
  13. test:/\.css$/,
  14. loader:'style!css'
  15. }]
  16. }
  17. };
  18. module.exports = config;

然后我们来进行加载

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注