day04--react中批量传递props

一、批量传递props

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

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

<!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.那么想要对对象进行展开,那么必须使用构造字面量对象,如下代码。

<!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的代码如下:

<!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. day04--react批量传递props

    2024-04-28 03:32:01       15 阅读
  2. ReactReactProps 传递给组件

    2024-04-28 03:32:01       17 阅读
  3. ReactProps传递数据与组件通信

    2024-04-28 03:32:01       31 阅读
  4. day04--reactstate的简化

    2024-04-28 03:32:01       13 阅读
  5. React04-关于React Props的实践

    2024-04-28 03:32:01       34 阅读
  6. day03--reactsetState的使用

    2024-04-28 03:32:01       14 阅读
  7. 深入理解 React 的 children props 和 render props

    2024-04-28 03:32:01       23 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-28 03:32:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-28 03:32:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-28 03:32:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-28 03:32:01       18 阅读

热门阅读

  1. 随手记:vue2 filters this指向undefined

    2024-04-28 03:32:01       12 阅读
  2. Qt——代码崩溃 free() invalid pointer

    2024-04-28 03:32:01       13 阅读
  3. Nacos

    Nacos

    2024-04-28 03:32:01      11 阅读
  4. ruoyi-cloud-plus的bom

    2024-04-28 03:32:01       11 阅读
  5. 【软考】面向对象设计

    2024-04-28 03:32:01       10 阅读
  6. 创建PAM配置文件

    2024-04-28 03:32:01       7 阅读
  7. C语言例题27:打印99乘法口诀表

    2024-04-28 03:32:01       9 阅读