09_DOM的Diffing算法

1.验证Diffing算法

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>验证diffing算法</title>
</head>

<body>
    <div id="test"></div>
    <script type="text/javascript" src="../js/18.2.0/react.development.js"></script>
    <script type="text/javascript" src="../js/18.2.0/react-dom.development.js"></script>
    <script type="text/javascript" src="../js/17.0.1/babel.min.js"></script>

    <script type="text/babel">
        class Time extends React.Component {

            state = {
                date: new Date()
            }


            //组件挂载完毕时
            componentDidMount() {
                setInterval(() => {
                    this.setState({
                        date: new Date()
                    })
                }, 1000);
            }

            render() {
                console.log('render')
                return (
                    <div>
                        <h1>hello</h1>
                        <input type="text" />
                        <span>现在是北京时间:{this.state.date.toTimeString()}</span>
                    </div>
                )
            }
        }

        // ReactDOM.render(<Time />, document.getElementById("test"))
        const root = ReactDOM.createRoot(document.getElementById('test'));
        root.render(
            <React.StrictMode>
                <Time />
            </React.StrictMode>
        );
    </script>
</body>

</html>

2.key的作用

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>

<body>
    <div id="test"></div>
    <script type="text/javascript" src="../js/17.0.1/react.development.js"></script>
    <script type="text/javascript" src="../js/17.0.1/react-dom.development.js"></script>
    <script type="text/javascript" src="../js/17.0.1/babel.min.js"></script>

    <script type="text/babel">
        /* 
        慢动作回放---使用index索引值作为key

            初始数据:
                { id: 1, name: 'ccc', age: 18 },
                { id: 2, name: 'ddd', age: 19 }

            初始的虚拟DOM:
                <li key=0>ccc---18 <input type="text"/></li>
                <li key=1>ddd---19 <input type="text"/></li>
            
            更新后的数据:
                { id: 3, name: '小王', age: 22 },
                { id: 1, name: 'ccc', age: 18 },
                { id: 2, name: 'ddd', age: 19 }
            
            更新数据后的虚拟DOM:
                <li key=0>小王---22 <input type="text"/></li>
                <li key=1>ccc---18 <input type="text"/></li>
                <li key=2>ddd---19 <input type="text"/></li>

---------------------------------------------------------------------------------------------------------------------------------
        慢动作回放---使用id索引值作为key

            初始数据:
                { id: 1, name: 'ccc', age: 18 },
                { id: 2, name: 'ddd', age: 19 }

            初始的虚拟DOM:
                <li key=1>ccc---18 <input type="text"/></li>
                <li key=2>ddd---19 <input type="text"/></li>
            
            更新后的数据:
                { id: 3, name: '小王', age: 22 },
                { id: 1, name: 'ccc', age: 18 },
                { id: 2, name: 'ddd', age: 19 }
            
            更新数据后的虚拟DOM:
                <li key=3>小王---22 <input type="text"/></li>
                <li key=1>ccc---18 <input type="text"/></li>
                <li key=2>ddd---19 <input type="text"/></li>


         */
        class Person extends React.Component {
            state = {
                persons: [
                    { id: 1, name: 'ccc', age: 18 },
                    { id: 2, name: 'ddd', age: 19 }
                ]
            }

            add = () => {
                const { persons } = this.state
                const p = {
                    id: persons.length + 1,
                    name: '小王',
                    age: 22
                }
                this.setState({
                    persons: [p, ...persons]
                })
            }
            render() {
                return (
                    <div>
                        <h2>展示人员信息</h2>
                        <button onClick={this.add}>添加一个人的信息</button>
                        <h3>使用index索引值作为key</h3>
                        <ul>
                            {
                                this.state.persons.map((personsObj, index) => {
                                    return <li key={index}>{personsObj.name}---{personsObj.age} <input type="text"/></li>
                                })
                            }
                        </ul>
                        <hr />
                        <hr />
                        <h3>使用id(数据的唯一值)作为key</h3>
                        <ul>
                            {
                                this.state.persons.map((personsObj, index) => {
                                    return <li key={personsObj.id}>{personsObj.name}---{personsObj.age} <input type="text"/></li>
                                })
                            }
                        </ul>
                    </div>
                )
            }
        }

        ReactDOM.render(<Person />, document.getElementById("test"))
    </script>
</body>

</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值