day04--react中批量传递props

一、批量传递props

如果我们要传递的数据有很多,一个一个传的话有点麻烦,所以可以使用对象来定义数据,然后使用ES6的语法扩展运算符进行传递。

1.首先说明扩展运算符只能对数组进行展开,如果要对对象进行展开的话是不可以的,因为会报错,如下代码。

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        let obj = {name: "李四",age: 19}
        console.log(...obj);//Uncaught TypeError: Spread syntax requires ...iterable[Symbol.iterator] to be a function
    </script>
</body>
</html>

2.那么想要对对象进行展开,那么必须使用构造字面量对象,如下代码。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        let obj = { name: "李四", age: 19 }
        console.log({ ...obj });
        //打印: {
        //     "name": "李四",
        //     "age": 19
        // }
    </script>
</body>

</html>

3.那么理解了扩展运算符的使用,批量传递props的代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>hello_react</title>
</head>

<body>
    <!-- 准备好一个容器 -->
    <div id="test"></div>
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="/react-development.js"></script>
    <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="/react-dom-development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="/babel.min.js"></script>
    <script type="text/babel">
        // 1.创建组件
        class Person extends React.Component {
            render() {
                const {name,age,sex} = this.props
                return (
                    <ul>
                        <li>名字:{name}</li>
                        <li>性别:{sex}</li>
                        <li>年龄:{age}</li>
                    </ul>
                )
            }
        }
        const p = {name: "李四",age: 18, sex: "女"}//外部要传递的数据
        // 因为引入react和使用了babel,那么我们就可以使用扩展运算符来展开对象
        // 但是对于原来的语法中,...扩展运算符只能展开数组,要想展开对象,必须使用构造字面量对象
        // 2.渲染虚拟DOM到页面
       	//{...p}:这里的{}并不是一个字面量对象,而是作为一个分割符使用,那么为什么...p可以使用,是因为引入react和使用了babel,它们帮我们使用构造字面量对象。
        ReactDOM.render(<Person {...p}/>, document.getElementById('test'))
    
    </script>
</body>

</html>
相关推荐
咖啡の猫1 小时前
Shell脚本-for循环应用案例
前端·chrome
百万蹄蹄向前冲4 小时前
Trae分析Phaser.js游戏《洋葱头捡星星》
前端·游戏开发·trae
朝阳5814 小时前
在浏览器端使用 xml2js 遇到的报错及解决方法
前端
GIS之路4 小时前
GeoTools 读取影像元数据
前端
ssshooter5 小时前
VSCode 自带的 TS 版本可能跟项目TS 版本不一样
前端·面试·typescript
你的人类朋友5 小时前
【Node.js】什么是Node.js
javascript·后端·node.js
Jerry6 小时前
Jetpack Compose 中的状态
前端
dae bal6 小时前
关于RSA和AES加密
前端·vue.js
柳杉6 小时前
使用three.js搭建3d隧道监测-2
前端·javascript·数据可视化
lynn8570_blog7 小时前
低端设备加载webp ANR
前端·算法