Skip to content

PanPanda/react-seed

 
 

Repository files navigation

Introduction

This repository is an universal React-ES6-Webpack boilerplate for developer to quickly build a super fast and powerful web app that can be rendered on the client using the most cutting-edge technology. Compared to others, this boilerplate has more pithily and more elegant configuration file based on environment variables, one for development, one for production.

Technology Stack

  • React
  • React-Router
  • ES6
  • jQuery
  • antd
  • Less
  • AnimateCSS
  • moment
  • Ajax
  • Mock
  • ECharts
  • Babel
  • Webpack
  • Yarn

Getting Started

安装Yarn $ npm install -g yarn
安装依赖 $ yarn
启动服务 $ yarn start
生成文件 $ yarn run build

Notes

  • JSX 的基本语法规则:遇到 HTML 标签(以 < 开头),就用 HTML 规则解析;遇到代码块(以 { 开头),就用 JavaScript 规则解析
  • 组件类的第一个字母必须大写
  • 组件类只能包含一个顶层标签
  • 组件的属性可以在组件类的 this.props 对象上获取
  • class 属性需要写成 className ,for 属性需要写成 htmlFor
  • this.props.children 属性表示组件的所有子节点
  • this.props.children 的值有三种可能:如果当前组件没有子节点,它就是 undefined ;如果有一个子节点,数据类型是 object ;如果有多个子节点,数据类型就是 array
  • React 提供一个工具方法 React.Children 来处理 this.props.children 。我们可以用 React.Children.map 来遍历子节点
  • 由于 this.refs.[refName] 属性获取的是真实 DOM ,所以必须等到虚拟 DOM 插入文档以后,才能使用这个属性,否则会报错
  • this.props 表示那些一旦定义,就不再改变的特性,而 this.state 是会随着用户互动而产生变化的特性
  • 我们写一个XML标签,实质上就是在调用 React.createElement 这个方法,并返回一个 ReactElement 对象
  • 渲染HTML标签,声明变量采用 首字母小写
  • 渲染React组件,声明变量采用 首字母大写
  • 当需要拓展我们的属性的时候,定义个一个属性对象,并通过 {…props} 的方式引入
  • 属性值使用表达式,只要用 {} 替换 ""
  • 在一个组件的子元素位置使用注释要用 {} 包起来
  • 直接在标签上使用style属性时,要写成style={{}}是两个大括号
  • margin-top要写成marginTop
  • 如果需要使用自定义属性,要加 data- 前缀
  • 在编写JSX时,在 { } 中不能使用语句(if语句、for语句等等),但可以使用求值表达式
  • map遍历的时候,需要为每一条记录添加key
  • 在ES6里,我们通过定义一个继承自React.Component的class来定义一个组件类
  • 给组件定义方法不再用 名字: function()的写法,而是直接用名字(),在方法的最后也不能有逗号了
  • 在ES6下,你需要通过bind来绑定this引用,或者使用箭头函数(它会绑定当前scope的this引用)来调用
  • sources下,点开可以看到webpack:目录,里面可以直接看到我们开发态的源代码,方便调试
  • "build": "rimraf app/dist && webpack -p --env.config production" 先清除dist目录

Articles

License

MIT

About

a Starter-Kit for React-ES6-Webpack(2.x) Project

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 86.2%
  • CSS 9.5%
  • HTML 4.3%