一.需求 当有传属性name的值时,则显示Hello "name",否则显示Hello World 二.4种方式的代码实现 1.通过三元运算符 <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body>…
React组件属性类型(propTypes)校验 Prop 验证 随着应用不断变大,保证组件被正确使用变得非常有用.为此我们引入propTypes.React.PropTypes 提供很多验证器 (validator) 来验证传入数据的有效性.当向 props 传入无效数据时,JavaScript 控制台会抛出警告.注意为了性能考虑,只在开发环境验证 propTypes.下面用例子来说明不同验证器的区别: React.createClass({ propTypes: { // 可以声明 prop…
1. propTypes 用于进行props的类型检查:来自于prop-types库. // V15.5之后 import PropTypes from 'prop-types'; 该方法适用于函数组件和class组件. 如果使用了@babel/plugin-proposal-class-properties插件, 可以直接在组件内部作为静态属性. class App extends React.Component { static propTypes = { name: PropTypes.s…
第二章 设计高质量的React组件 高质量React组件的原则和方法: 划分组件边界的原则: React组件的数据种类: React组件的生命周期. 2.1 易于维护组件的设计要素 1.高内聚:指的是把逻辑紧密相关的内容放在一个组件中.用户界面包括:内容.交互行为.样式. 2.低耦合:指的是不同组件之间的依赖关系要尽量弱化,也就是第个组件要尽量独立. 2.2 React组件的数据 React组件的数据分两种,prop和state,作何一个改变,都可能引发组件的重新渲染. 选prop or sta…
Prop验证 随着应用不断变大,为了保证组件被正确使用变得越来越重要.为此我们引入propsTypes.React.PropTypes提供很多验证器(valodator)来验证传入的数据的有效性.当向props传入无效数据是,JavaScript控制台会抛出错误.为了性能考虑,只在开发环境验证propsTypes. GroupSelect.defaultProps = {};GroupSelect.propTypes = { name: PropTypes.string, children: P…
在编码时,由于开始是在winform下进行简单的测试开发的,后来代码多了,就想分到不同的类里边去,可是因为原来的测试是在同一个form下的,所以对于函数调用可以很方便,而一旦跨类之后,就会发现,这函数的耦合度太高,以至于不知道该怎么样解耦到类里边去.这时,不妨使用委托类型的Func和Action来实现. 下面是最开始测试时在winform里写的简单代码 using System; using System.Collections.Generic; using System.ComponentMo…
如果有这样一个结构:三级嵌套,分别是:一级父组件.二级子组件.三级孙子组件,且前者包含后者,结构如图: 如果把一个属性,比如color,从一级传递给三级,一般做法是使用props逐一向下传递,代码如下: // 一级父组件 class Level1 extends React.Component{ render(){ return <Level2 color='red'/> } } // 二级子组件 class Level2 extends React.Component{ render(){…
目录: . 组件名字首字母一定是大写的 . 返回一个jsx . jsx依赖React,所以组件内部需要引入React . 组件传参 a. 传递. <Component list={ arrData }><Component> b. 接收. function Component( props ){...} c. 使用. const { list } = props,list就是参数数据 . 缺点:[无状态组件]只能实现很简单的视图展示功能,没有自己的内容数据.没有状态,没有逻辑处理,…
一.概述 React中的组件: 解决html 标签构建应用的不足. 使用组件的好处:把公共的功能单独抽离成一个文件作为一个组件,哪里里使用哪里引入. [父子组件]:组件的相互调用中,我们把调用者称为父组件,被调用者称为子组件 - -------------------------------------------------------------------- 二.父子组件传值 父组件给子组件传值方法分为2步: 1.父:在调用子组件的时候定义一个属性: <Header msg='首页'>&…
第十二单元(react路由-使用react-router-dom-认识相关的组件以及组件属性) #课程目标 理解路由的原理及应运 理解react-router-dom以及内置的一些组件 合理应用内置组件及其属性搭建项目路由 #知识点 路由的由来 路由就是指随着浏览器地址栏的变化,展示给用户的页面也不相同.这是从路由的用途上来解释路由是什么的,还有一种说法是:路由就是URL到函数的映射. 1-1. hash => 路由的实现就是基于location.hash来实现的.其实现原理也很简单,locat…