React学习笔记16-属性props
1.属性的定义
2.属性的特点
3.属性的用法
import React, { Component } from 'react'
import Navbar from './Navbar'
export default class App extends Component {
state = {
//只能内部自己使用,外部无法改变
}
render() {
//上面父组件传来的一个对象
var obj = {
title: '测试',
leftshow: false
}
return (
<div>
<h2>首页</h2>
<Navbar title="首页" leftshow={false} ></Navbar>
<h2>列表</h2>
<Navbar title="列表" leftshow={true} rightshow={true}></Navbar>
<h2>购物车</h2>
{/* 如果对象里面的属性和组件的属性key一样可以用拓展运算符直接结构obj放入组件 */}
<Navbar title="购物车" {...obj}></Navbar>
</div>
)
}
}
import React, { Component } from 'react'
import propTypes from "prop-types"
export default class Navbar extends Component {
//a=100对象属性
state = {
//只能内部自己使用,外部无法改变
}
//用static修饰属性就是类属性
static propTypes = {
title: propTypes.string,
leftshow: propTypes.bool,
rightshow: propTypes.bool,
}
//用static修饰属性就是类属性
static defaultProps = {
//属性默认值
leftshow: true,
rightshow: true,
title: ''
}
//属性是父组件传过来的,this.props
render() {
console.log(propTypes)
let { title, leftshow, rightshow } = this.props
return (
<div style={{ display: 'flex' }}>
{leftshow && <button>返回</button>}
{/* <div>{ this.props.title}</div> */}
<div>{title}</div>
{rightshow && <button>Home</button>}
</div>
)
}
}
// Navbar.defalutProps={
// leftshow:false,
// rightshow:true,
// title:''
// }
/* Navbar.propTypes = {
title: propTypes.string,
leftshow: propTypes.bool,
rightshow: propTypes.bool,
} *///类属性
/*
给组件类加上一个propTypes属性在里面使用prop-types模块封装好的方法即可
验证属性
*/
import React, { Component } from 'react'
import Navbar from './Navbar'
import Sidebar from './Sidebar'
export default class App extends Component {
render() {
return (
<div>
{/* 类组件 */}
<Navbar title="导航"></Navbar>
{/* 函数式组件 */}
<Sidebar bg="yellow" position="left"></Sidebar>
</div>
)
}
}
import React from 'react'
import propTypes from "prop-types"
export default function Sidebar(props) {
console.log(props)
let { bg, position } = props
let obj = { backgroundColor: bg, position: "fixed" }
let obj1 = { right: 0 }
let obj2 = { left: 0 }
// eslint-disable-next-line eqeqeq
position == 'right' ? obj = { ...obj1, ...obj } : obj = { ...obj2, ...obj }
return (
<div style={obj}>
<ul>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
</ul>
</div>
)
}
//Sidebar.defaultProps 默认属性
Sidebar.defaultProps = {
bg: 'red',
position: 'fixed'
}
//Sidebar.propTypes 属性验证
Sidebar.propTypes = {
bg: propTypes.string,
position: propTypes.string
}
//用static修饰属性就是类属性
static defaultProps = {
//属性默认值
leftshow: true,
rightshow: true,
title: ''
}
在函数组件中,通过 函数名.defaultProps来设置属性的默认值
import React from 'react'
export default function Sidebar(props) {
console.log(props)
let { bg, position } = props
let obj = { backgroundColor: bg, position: "fixed" }
let obj1 = { right: 0 }
let obj2 = { left: 0 }
// eslint-disable-next-line eqeqeq
position == 'right' ? obj = { ...obj1, ...obj } : obj = { ...obj2, ...obj }
return (
<div style={obj}>
<ul>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
</ul>
</div>
)
}
//Sidebar.defaultProps 默认属性
Sidebar.defaultProps={
bg:'red',
position:'fixed'
}
4).设置属性的类型验证,可以通过设置属性的类型验证来限制属性的类型。
注意在进行类型验证时需要先导入React自带的prop-types
import propTypes from "prop-types"
同样类组件是通过静态属性propTypes来设置类型验证
static propTypes = {
title: propTypes.string,
leftshow: propTypes.bool,
rightshow: propTypes.bool,
}
函数组件是通过组件名.propTypes来设置类型验证
import React from 'react'
import propTypes from "prop-types"
export default function Sidebar(props) {
console.log(props)
let { bg, position } = props
let obj = { backgroundColor: bg, position: "fixed" }
let obj1 = { right: 0 }
let obj2 = { left: 0 }
// eslint-disable-next-line eqeqeq
position == 'right' ? obj = { ...obj1, ...obj } : obj = { ...obj2, ...obj }
return (
<div style={obj}>
<ul>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
<li>11111</li>
</ul>
</div>
)
}
//Sidebar.defaultProps 默认属性
Sidebar.defaultProps = {
bg: 'red',
position: 'fixed'
}
//Sidebar.propTypes 属性验证
Sidebar.propTypes = {
bg: propTypes.string,
position: propTypes.string
}
React学习笔记16-属性props的更多相关文章
- react学习笔记_03-组件&props
组件 & Props的学习 组件允许你将 UI 拆分为独立可复用的代码片段,并对每个片段进行独立构思. 组件,从概念上类似于 JavaScript 函数.它接受任意的入参(即 “props”) ...
- React学习笔记 - 组件&Props
React Learn Note 4 React学习笔记(四) 标签(空格分隔): React JavaScript 三.组件&Props 组件可以将UI切分成一些独立的.可复用的部件,这样你 ...
- react学习笔记1--基础知识
什么是react A JAVASCRIPT LIBRARY FOR BUILDING USER INTERFACES[React是一个用于构建用户界面的JavaScript库.] React之所以快, ...
- React学习笔记(一)- 入门笔记
React入门指南 作者:狐狸家的鱼 本文链接:React学习笔记 GitHub:sueRimn 1.组件内部状态state的修改 修改组件的每个状态,组件的render()方法都会再次运行.这样就可 ...
- React学习笔记(六)事件处理
React学习笔记(六) 五.事件处理 React事件绑定属性的命名采用驼峰写法,不同于传统DOM全部小写. 如果采用JSX的语法,事件函数需要用大括号{}包裹函数名,不同于传统DOM字符串小括号的方 ...
- React学习笔记(五)State&声明周期
React学习笔记(五) 四.State&声明周期 可以为组件添加"状态(state)".状态与属性相似,但是状态是私有的,完全受控于当前组件. 局部状态就是只能用于类(定 ...
- React学习笔记 - JSX简介
React Learn Note 2 React学习笔记(二) 标签(空格分隔): React JavaScript 一.JSX简介 像const element = <h1>Hello ...
- Ext.Net学习笔记16:Ext.Net GridPanel 折叠/展开行
Ext.Net学习笔记16:Ext.Net GridPanel 折叠/展开行 Ext.Net GridPanel的行支持折叠/展开功能,这个功能个人觉得还说很有用处的,尤其是数据中包含图片等内容的时候 ...
- SQL反模式学习笔记16 使用随机数排序
目标:随机排序,使用高效的SQL语句查询获取随机数据样本. 反模式:使用RAND()随机函数 SELECT * FROM Employees AS e ORDER BY RAND() Limit 1 ...
- React学习笔记(七)条件渲染
React学习笔记(七) 六.条件渲染 使用if或条件运算符来创建表示当前状态的元素. 可以使用变量来存储元素.比如: let button = null; if (isLoggedIn) { but ...
随机推荐
- Android 妙用TextView实现左边文字,右边图片
原文: Android 妙用TextView实现左边文字,右边图片 - Stars-One的杂货小窝 有时候,需要文字在左边,右边有个箭头,我个人之前会有两种做法: 使用线性布局来实现 或者使用约束布 ...
- Blazor前后端框架Known-V1.2.5
V1.2.5 Known是基于C#和Blazor开发的前后端分离快速开发框架,开箱即用,跨平台,一处代码,多处运行. Gitee: https://gitee.com/known/Known Gith ...
- PE结构总览
pe文件经历了从16位系统到32位系统的过度.因此32系统下的每一个PE文件都可以在16位系统下运行. 16位系统下的PE结构 在16位系统下,PE结构可以大致分为两个部分:DOS头和一些其他数据 # ...
- C# LinearGradientBrush使用报错
今天在学习C#时使用 LinearGradientBrush 属性发生了如上错误,发现引用其时并没有提示 在添加了此命名空间后恢复正常
- 【VS Code 与 Qt6】QAction 类的一些事
QAction 类表示用户命令的一种抽象,包括命令文本.图标.命令触发后要执行的代码.菜单.工具栏按钮往往存在相同的功能,将这些命令独立抽出来,放到 QAction 以象上,可避免编写重复的代码.比如 ...
- Linux中对管道命令中的任意子命令进行返回码校验
~~ linux return code with pipeline~~ ~~ linux 管道命令中的返回码~~ BASH SHELL中,通常使用 $? 来获取上一条命令的返回码. Shell Sc ...
- 角度新奇!第一次看到这样使用MyBatis的,看得我一愣一愣的。
你好呀,我是歪歪. 这期给大家分享一个读者给我分享的一个关于 MyBatis 的"编程小技巧",说真的,这骚操作,直接把我看得一愣一愣的. 我更情愿叫它:坑你没商量之埋雷大法. D ...
- #Powerbi 1分钟学会,RANK函数,多字段排名函数.
一:思维导图&数据源示例 1.1思维导图 1.2示例数据源 二:参数构成 三:案例度量值 基础度量值 总销量 = CALCULATE(SUM('数据源'[销量])) 总销售额 = CALCUL ...
- [远程Call]32位远程多参数带返回调用
[远程Call]32位远程多参数带返回调用 引子 在Windows上可以使用CreateRemoteThread实现远程Call,但是有不带返回值且只能传递一个参数的限制. 解决思路 将多个参数利用V ...
- 数据可视化【原创】vue复合数字形式展示
做数据可视化的时候,经常碰到需要很灵活的数字形式展示. 先上个效果图: 如图包括名称,数量,别名,单位,上升下降,环比等等的复合数据展示,并且需要支持样式灵活配置. 此组件包括2个模块,父容器组件bo ...