0
点赞
收藏
分享

微信扫一扫

VUE框架解析虚拟dom和diff算法是如何提高我们的vue渲染效率的------VUE框架

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/vue.js"></script>
    <style>
        th,td{border: 1px solid black;}
    </style>
</head>
<body>
    <div id="app">
        <h1>{{msg}}</h1>
        <table>
            <tr>
                <th>序号</th>
                <th>英雄</th>
                <th>能量值</th>
                <th>选择</th>
            </tr>
            <!-- VUE框架是采用了虚拟dom和diff算法来提高执行效率的 -->
            <!-- 虚拟dom是在内存中的dom对象 -->
            <!-- diff算法,可以快速比较两个对象的不同之处 -->
            <!-- 当我们没有设置key的时候,默认的key就是我们的index作为key的 -->
            <!-- v-for所在的标签中有一个很重要的属性key,这个key是这个dom元素的身份证号或者说唯一标识 -->
            <!-- 当我们没有设置key的时候默认为index作为key的标识 -->
            <!-- 内存中的虚拟dom生成的每一个tr上都会标识有一个唯一的key做区分 -->
            <!-- 类似于我们实体dom树上的id -->
            <!-- 当我们的diff算法比对时,发现没有变化,不会重新渲染,而是直接复用 -->
            <!-- 甚至连子元素都可以复用比较,不需要创建 -->
            <!-- 新的虚拟dom实际是在内存中的,他和老的已经渲染出来的实际dom进行比对 -->
            <!-- 比对不一样才修改,一样部分直接原地使用即可 -->
            <tr v-for="(hero,index) in heros">
                <td>{{index}}</td>
                <td>{{hero.name}}</td>
                <td>{{hero.power}}</td>
                <td><input type="checkbox"/></td>
            </tr>
        </table>
    </div>
    <script>
        const vm = new Vue({
            el : "#app",
            data : {
                msg : "Hello",
                heros : [
                    {id:"101",name:"Jerry",power:10000},
                    {id:"102",name:"Tom",power:9000},
                    {id:"103",name:"Jack",power:8000},
                    {id:"104",name:"Rose",power:6000}
                ]
            }
        });
    </script>
</body>
</html>

举报

相关推荐

0 条评论