React系列学习笔记:1.React与webpack基本配置

前言

webpack和react搭配开发非常棒可以说是最佳的搭档了,包在安装过程中开发用的使用npm install --save-dev <name>安装,生产环境需要的包用npm install --save <name>安装,国内由于网络环境建设使用淘宝的镜像源cnpm,本节使用的包列表:

  • babel一系列编译转换工具:
    babel-core babel-cli babel-loader babel-preset-es2015 babel-preset-react
  • React库:react react-dom

目录结构

|-React-redux-example
    |-node_modules/                 #包文件
    |-public/                       #静态目录
        |-assets/                   #静态资源生成目录
        |-index.html
    |-src/                          #开发目录
        |-app.js                    #client入口文件
    |-config/                       #配置目录
        |-webpack.dev.js            #webpack开发配置文件
    |-package.json      
    |-README.md
    |-.gitignore                    #git的忽略列表

config/webpack.dev.js

var path = require('path')

//配置文件是放在config的目录下的,所有这里定义了一个项目的根目录变量
var projectRootPath = path.resolve(__dirname,'..') 

var config = {
  entry: path.resolve(projectRootPath,'src/app.js'),
  output:{
    path: path.resolve(projectRootPath,'public','assets'),
    filename: 'bundle.js',
    publicPath: '/assets/'
  },
  module:{
    loaders:[
      {
        test:/\.js$/,
        exclude:/node_modules/,
        loader:'babel-loader',
        query:{
          presets:['react','es2015']
        }
      }
    ]
  }
}

module.exports=config;

entry:要打包文件
output:打包文件位置
module:打包要加载的模块--presets用来解析ES6,React,ES7语法
publicPath:指定公共URL地址在浏览器输出文件的引用

package.json

scripts添加webpack的编译命令,由于我的webpack配置文件,放在config目录中,所以在编译时要指定--config ./config/webpack.dev.js

  "scripts": {
    "build": "webpack --verbose --color --display-error-details --config ./config/webpack.dev.js "
  }

src/app.js

这里我们用最少的代码测试一下我们的webpack配置有没有问题

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

ReactDOM.render(<h1>Hello</h1>,document.getElementById('app'))

public/index.html

因为没有启动web服务器,所以<script src="./assets/bundle.js"></script>用的是文件的相对地址

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>React-redux-example</title>
</head>
<body>
  <div id="app"></div>
</body>
<script src="./assets/bundle.js"></script>
</html>

build

完成上面所有步骤后,npm run build会看到在public/assets/目录中生成了一个bundle.js文件,在浏览器中打开index.html看到Hello,我们的webpack基本配置就完成了,如图

NEXT

webpack与express开发服务器的配置,hotreplace(热替换)的配置

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,227评论 7 35
  • 构建一个小项目——FlyBird,学习webpack和react。(本文成文于2017/2/25) 从webpac...
    布蕾布蕾阅读 16,873评论 31 98
  • 最近在学习 Webpack,网上大多数入门教程都是基于 Webpack 1.x 版本的,我学习 Webpack 的...
    My_Oh_My阅读 8,204评论 40 247
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,324评论 4 31
  • 现在的这些年轻人啊,和我们以前真是不一样了…… 金钱观 可喜的是,现在的年轻人终于不再遮掩自己的欲望了。 对,我就...
    时辰君阅读 252评论 0 0