React之props限制

<!DOCTYPE html>

<html>

<head>

    <meat charset="UTF-8">

        <title>2_props限制</title>

</head>

<body>

    <!-- 准备好一个容器 -->

    <div id="test1"></div>

    <div id="test2"></div>

    <div id="test3"></div>

    <!-- 核心库 -->

    <script type="text/javascript" src="../js/react.development.js"></script>

    <!-- react-dom,操作dom -->

    <script type="text/javascript" src="../js/react-dom.development.js"></script>

    <!-- 引入babel,jsx转为js -->

    <script type="text/javascript" src="../js/babel.min.js"></script>

    <!-- 引入prop-types,限制组件标签属性 -->

    <script type="text/javaScript" src="../js/prop-types.js"></script>

    <!-- 此处一定要写babel -->

    <script type="text/babel">

        //1.创建组件

        class Person extends React.Component{            

           render(){  

               console.log(this);

               const {name,age,sex} = this.props      

               return(

                   <ul>

                        <li>姓名:{name}</li>

                        <li>性别:{sex}</li>

                        <li>年龄:{age+1}</li>

                    </ul>

               )

           }          

        }

        //对标签属性进行类型、必须性的限制

        Person.propTypes = {

            name:PropTypes.string.isRequired,//限制name必传,且为字符串

            sex: PropTypes.string,//限制sex为字符串

            age: PropTypes.number,//限制age为数值

            speak: PropTypes.func,//限制speak为函数

        }

        //指定默认标签属性值

        Person.defaultProps = {

            sex:'男',//sex默认值为男

            age:18//age默认值为18

        }

        //2.渲染组件到页面

        ReactDOM.render(<Person name='Tom44' age={19} sex="男" speak={speak}/>, document.getElementById('test1'));  

        ReactDOM.render(<Person name="lucy" age={13} />, document.getElementById('test2'));

        const p={name:'Toms',age:18,sex:'女'}

        console.log('@',...p)

        //ReactDOM.render(<Person name={p.name} age={p.age} sex={p.sex} />, document.getElementById('test3'));    

        ReactDOM.render(<Person {...p} />, document.getElementById('test3'));

        function speak(){

            console.log('我说话了')

        }    

    </script>

</body>

</html>

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/524637.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

msyql之事务

--事务 --转账 create database shop character set utf8 collate utf8_general_ci use shop create table account( id int(3) not null auto_increment, NAMEvarchar(30) not null, moneydecimal(9,2) not null, primary key(id) )engineinnodb default cha…

云评测 | OpenStack智能运维解决方案 @文末有福利!

戳蓝字“CSDN云计算”关注我们哦&#xff01;文章摘自 | 《OpenStack架构分析与实践》谈到OpenStack&#xff0c;一个难以避免的话题就是运维&#xff0c;对于OpenStack的运维而言&#xff0c;随着其项目的不断增多&#xff0c;传统的“人肉运维”方式显然不能满足当下及以后的…

C/C++ ceil 函数 - C语言零基础入门教程

目录 一.ceil 函数简介二.ceil 函数使用三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐 :…

通信协议讲解

协议&#xff1a;约定&#xff0c;好比说的普通话 网络通信协议:速率&#xff0c;传输码率&#xff0c;代码结构&#xff0c;传输控制...... 问题&#xff1a;非常的复杂&#xff1f; 大事化小&#xff1a;分层&#xff01; TCP/IP协议簇&#xff1a;实际上是一组协议 重要…

要闻君说: 百度云喜提信息安全首证;紫光展锐携5G芯片进击2019MWC;OPPO首发5G手机惊艳亮相……...

关注并标星星CSDN云计算每周三次&#xff0c;打卡即read更快、更全了解泛云圈精彩newsgo go go 大家好&#xff01;偶是要闻君。活动多多、新闻不少&#xff0c;精神饱满的周一&#xff0c;学起来&#xff01;&#xff01;&#xff01;文/要闻君一年一度&#xff0c;十分重磅&a…

C/C++ floor 函数 - C语言零基础入门教程

目录 一.floor 函数简介二.floor 函数使用三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐…

Tcp实现聊天讲解

客户端&#xff1a; 1.连接服务器Socket 2.发送消息 服务端&#xff1a; 1.建立服务端口ServerSocket 2.等待用户的连接accept 3.接收用的消息 package com.wuming.lesson02;import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStr…

Spring精华问答 | Spring Boot有哪些优点?

戳蓝字“CSDN云计算”关注我们哦&#xff01;Spring是于2003 年兴起的一个轻量级的Java 开发框架&#xff0c;为了解决企业应用开发的复杂性而创建的。今天&#xff0c;我们一起来看看关于Spring更加有深度的问答吧。。1Q&#xff1a;Spring Boot有哪些优点&#xff1f;A&#…

C/C++ round 函数 - C语言零基础入门教程

目录 一.round 函数简介二.round 函数使用三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐…

基于Kubernetes的持续部署方案

戳蓝字“CSDN云计算”关注我们哦&#xff01;文章转载自Docker方案概述本技术方案为基于Kubernetes为核心的持续部署&#xff08;下文简称CD&#xff09;方案&#xff0c;可以满足开发方的程序级日志查看分析&#xff0c;运维方的快速扩容与日常运维分析&#xff0c;并且可以保…

C/C++ abs 函数 - C语言零基础入门教程

目录 一.abs 函数简介二.abs 函数使用三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐 : C…

Tcp实现文件上传

package com.wuming.lesson02;import java.io.*; import java.net.ServerSocket; import java.net.Socket;public class TcpServerDemo02 {public static void main(String[] args) throws Exception {//1.创服务ServerSocket serverSocket new ServerSocket(9000);//2.监听客…

C/C++ fabs 函数 - C语言零基础入门教程

目录 一.fabs 函数简介二.fabs 函数使用三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐 :…

云存储精华问答 | 如何选择云迁移策略?

戳蓝字“CSDN云计算”关注我们哦&#xff01;云存储是在云计算概念上延伸和发展出来的一个新的概念&#xff0c;是一种新兴的网络存储技术&#xff0c;是指通过集群应用、网络技术或分布式文件系统等功能&#xff0c;将网络中大量各种不同类型的存储设备通过应用软件集合起来协…

UDP消息发送

package com.wuming.lesson03;import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.SocketException;//还是要等待客户端的连接 public class UdpServerDemo01 {public static void main(String[] args) throws Exception {//1.开放端口Datagram…

C/C++ 余弦函数 cos - C语言零基础入门教程

目录 一.cos 函数简介二.cos 函数实战三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐 : C…

云重磅|中西合璧 联想凌拓瓜熟蒂落;5G实锤 华为推出首部5G折叠手机;​IBM打造Kubernetes无处不在”的模式...

戳蓝字“CSDN云计算”关注我们哦&#xff01;嗨&#xff0c;大家好&#xff0c;重磅君带来的【云重磅】特别栏目&#xff0c;如期而至&#xff0c;每周二第一时间为大家带来重磅新闻。把握技术风向标&#xff0c;了解行业应用与实践&#xff0c;就交给我重磅君吧&#xff01;重…

C/C++ 正弦函数 sin - C语言零基础入门教程

目录 一.sin 函数简介二.sin 函数实战三.猜你喜欢 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 语言基础入门 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 面向对象 零基础 C/C 学习路线推荐 : C/C 学习目录 >> C 设计模式 零基础 C/C 学习路线推荐 : C…

云计算精华问答 | 边缘计算、雾计算、霾计算,它们究竟是什么?

戳蓝字“CSDN云计算”关注我们哦&#xff01;物联网对于数据的处理能力要求很高&#xff0c;怎么能够从庞大的数据海中挖掘一些有价值的信息对于物联网的发展至关重要&#xff0c;因此云计算&#xff0c;雾计算&#xff0c;边缘计算等等都将发挥其左右。今天&#xff0c;就让我…

IOS – OPenGL ES 设置图像亮度 GPUImageBrightnessFilter

目录 一.简介二.效果演示三.源码下载四.猜你喜欢 零基础 OpenGL (ES) 学习路线推荐 : OpenGL (ES) 学习目录 >> OpenGL ES 基础 零基础 OpenGL (ES) 学习路线推荐 : OpenGL (ES) 学习目录 >> OpenGL ES 转场 零基础 OpenGL (ES) 学习路线推荐 : OpenGL (ES) 学习目…