Skip to content

Files

Latest commit

 

History

History
119 lines (112 loc) · 6.91 KB

README.md

File metadata and controls

119 lines (112 loc) · 6.91 KB

A react template with webpack for building your react SPA

一款专门适配react开发的webpack模板

Based on webpack (3.8.1), react-router-dom (4.3.1) and react (16.5.2)

功能

  1. css,less,stylus解析编译,想要使用less或stylus,必须要自己手动npm安装对应的less或stylus。
  2. css内图片自动解析并添加hash缓存,字体图标也支持,但在引入阿里的iconfont必须要手动更iconfont.css内的路径为相对路径。
  3. jsx和ES6语法解析,自动识别jsx文件,并且支持ES6最新语法,支持stage3语法,例如async函数,也支持类的新属性和静态属性写法。
  4. 支持webpack动态导入,配合import语法和react-loadable实现异步组件。
  5. 开发模式支持devServer,默认端口为8080,config.js提供了很多可配置项。默认提供eval-source-map供调试。
  6. 开发模式支持react-hotloader热替换,已经在App.jsx配置好,代码修改不会重新刷新页面而是局部更改。
  7. 集成了react和react-rotuer-dom,并二次封装了原有的Route组件让嵌套路由配置更简单。并没有提供reduc或者mobx。
  8. 生产模式支持提取公共chunks打包,默认将开发代码和第三方库以及webpack运行的runtime文件分离。默认打包压缩混淆并提供source-map供调试。
  9. 模板默认设置打包文件所有资源为相对路径,这是为了避免放到服务器时文件不在根目录导致路径出错的问题。打包完后,你可以直接打开index.html访问。但是要注意如果项目里有路由,直接打开index.html可能页面空白。这是因为路由必须要放在服务器才生效,必须保证根路由打开index.html。为了避免这种问题,模板内置一个静态文件服务器,通过npm run preview调用。

Directory Tree

    ─src
    │  ├─assets
    │  ├─components
    │  │  └─Hello
    │  ├─router
    │  └─views
    │      └─Home
    └─webpack.config

强烈建议按照模板目录来进行开发,可以新增,不要删除

  • assets是资源,componets是组件,router是路由(已配置好),views是页面级组件,static是静态资源(最终会复制一份到dist的static目录下)
  • 基于react-router-dom,模板对Route组件进行了封装,为了更简单实现多层嵌套路由,模仿vue-router的api
  • 模板提供了3个路径符号,@ => src目录components => src/components目录views => src/views目录static => static目录

使用

  1. 使用alan-cli安装,极为便捷,使用方法见alan-cli**
  2. npm install 安装所有开发依赖和打包依赖
  3. npm start 或者 npm run dev 启动开发环境
  4. npm run build 启动打包程序,默认会在项目根目录生产dist文件夹,index.html在dist根目录,其余静态资源放在static文件夹内
  5. npm run preview 启动一个静态文件服务器,默认以dist文件夹作为根目录,目的是为了测试打包后项目是否可以正常访问,只作为一种前端自测手段

开发tips

  • SPA单页面应用大部分都是在开发组件和路由,本模板直接在App.jsx中最外层设置了根路由,新增页面只需要在router/routeConfig中添加路由参数即可
  • 模板中二次封装的路由组件为RouterView,该组件和react-router-dom原生组件不会冲突,如果你想快速配置嵌套路由,建议使用RouterView和配置文件,你也可以单独使用react-router-domRoute组件
  • RouterView组件模仿vue-router的配置,routeConfig.jsx中的配置格式如下:
    /*  routeConfig.jsx   */
    export default [
        {
            path: '/',
            exact: true,        // Route组件原生的props
            strict: false,      // Route组件原生的props
            sensitive: true,    // Route组件原生的props
            component: Home
        }
        {
            path: '/sub',       // 和'/'在同一级的均为根级路由,根级路由也是一层路由,在使用RouterView组件时,不需要传入match的props
            component: Sub,
            children: [         // 嵌套路由只需要在当前父级路由下新增children选项,在使用RouterView组件时,必须传入match的props
                {
                    path: 'hello', // 嵌套路由可以加'/'前缀或者不加,已做兼容处理
                    component: Hello
                },
                {
                    path: '/world',
                    component: World,
                    children: [   // RouterView组件支持多级嵌套,会自动找寻对应层级的路由参数
                        {
                            path: 'a',
                            component: () => {
                                return <h3>this is world A</h3>
                            }
                        },
                        {
                            path: 'b',
                            component: () => {
                                return <h3>this is world B</h3>
                            }
                        }
                    ]
                }
            ]
        }
    ]

    /* App.jsx  */
    export default class App extends Component {
        render() {
            return (
                <div>
                    <h1>welcome to react</h1>
                    <RouterView /> /* 在根路由的外层容器里引入该组件,可以不传任何props,默认加载所有一级路由 */
                </div>
            )
        }
    }
    /* Sub.jsx  */
    export default class Sub extends Component {
        constructor(props) {
            super(props)
        }
        render() {
            return (
                <div>
                    <h1>this is Sub</h1>
                /* 
                   在嵌套路由的外层容器里引入该组件,必传match,this.props.match是Home的父级组件Route传入的值,具体见react-router-dom文档。
                   默认加载当前match对应下的直接子路由 
                */
                    <RouterView match={this.props.match} /> 
                </div>
            )
        }
    }

注意事项

  • 模板支持less和stylus,但是必须要自己安装less或者stylus才有效,如果想使用sass,请自己在webpack.dev.js和webpack.prod.js内添加sass-loader
  • 模板并没有提供redux或mobx,请注意,redux或者mobx配置可能需要更改react-loadablereact-hotloader,以具体文档为主
  • RouterView只是为了方便,你可以选择不使用,直接不在具体组件内调用即可,只有调用,路由配置才会生效。你甚至可以和原有的Route,Link,Switch等组件混搭,RouterView并没有改变什么,所以你也可以在其子组件中通过this.props.match获取到路由信息
  • npm run preview只有在npm run build才有效,否则打开服务器页面为空白