ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Vue列表渲染 key 过滤 排序

2022-02-01 11:34:17  阅读:187  来源: 互联网

标签:index Vue name 复用 tag key 排序 id


列表渲染

可以遍历数组,对象,字符串以及指定次数

demo

<!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>
<script src="../lib/vue.js"></script>

<body>
    <div id="root">
        <ul>
            <h1>遍历数组</h1>
            <li v-for="(p,index) in persons" :key="p.id">
                <span>{{p.name}}-{{p.id}}</span>
            </li>
            
            <h1>遍历对象</h1>
            <li v-for="(value,key) of personObj" :key="key" >
                <span>{{value.name}} - {{value.id}}</span>
            </li>

            <h1>遍历字符串</h1>
            <li v-for="(value,index) in personStr" >
                <span>{{value}} - {{index}}</span>
            </li>

            <h1>遍历指定次数</h1>
            <li v-for="index of 5" >
                <span>{{index}}</span>
            </li>
        </ul>
    </div>
    <script>
        const vm = new Vue({
            el: "#root",
            data: {
                persons: [
                    { name: 'island1', id: 1 },
                    { name: 'island2', id: 2 },
                    { name: 'island3', id: 3 }
                ],
                personObj:{
                    island1: { name: 'island1', id: 1 },
                    island2: { name: 'island2', id: 2 },
                    island3: { name: 'island3', id: 3 }
                },
                personStr:'island1'
            }
        })
    </script>
</body>

</html>

key的作用 key与index

key的作用主要是diff的时候去判断是否复用节点还是创建新的节点。

拿react说,如果key一样,并且type一样,那么表示这个节点可以复用。如果不能复用,那么就涉及到新内存的申请和旧对象内存的回收,性能上表现不一样
(content 文案不一样? 文案是作为子节点的,我们讨论的是复用当前节点)

index作为key只适用于数组的尾部操作,即数据的操作是保证先后顺序的
假如在数组头插入一个数据,以index作为key的话,那么key和type都是相同的,可以复用,就会造成第一条新数据的dom复用原来的第一个节点,导致界面出错

列表渲染、过滤、排序

<!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>
<script src="../lib/vue.js"></script>

<body>
    <div id="root">
        <!-- 列表渲染 -->
        <ul style="display: none;">
            <button @click="add()">头插数组</button>
            <li v-for="(p,index) in persons" :key="index">
                <span>{{index}}</span>
                <input type="text">
            </li>
        </ul>
        <!-- 列表过滤 -->
        <ul>
            <input type="text" v-model="keyword" />
            <button @click="sort({tag:sortTagMap.ascend})">id升序</button>
            <button @click="sort({tag:sortTagMap.descend})">id降序</button>
            <button @click="sort({tag:sortTagMap.origin})">原顺序</button>
            <li v-for="(p,index) in filterPersons" :key="p.id">
                <span>{{p.name}}</span>
            </li>
        </ul>
    </div>
    <script>
        const vm = new Vue({
            el: "#root",
            data: {
                sortTagMap: {
                    ascend: 'ascend',
                    descend: 'descend',
                    origin: 'origin'
                },
                tag: 'origin',
                keyword: "",
                persons: [
                    { name: '1-island', id: 1 },
                    { name: '2-island', id: 2 },
                    { name: '3-island', id: 3 }
                ]
                // filterPersons:[]
            },
            methods: {
                add: function () {
                    this.persons.unshift({ id: 4 })
                },
                sort({ tag }) {
                    console.log(tag);
                    
                    this.tag = tag
                }
            },
            // watch: {
            //     keyword: {
            //         immediate: true,
            //         handler() {
            //             this.filterPersons = this.persons.filter(v => v.name.includes(this.keyword))
            //         }
            //     }
            // },
            computed: {
                filterPersons() {
                    const { sortTagMap: map, tag } = this
                    const sorter = tag === map.origin ? () => { } : (tag === map.ascend ? (a, b) => a.id - b.id : (a, b) => b.id - a.id)
                    return this.persons.filter(v => v.name.includes(this.keyword)).sort(sorter)
                }
            }

        })
    </script>
</body>

</html>

标签:index,Vue,name,复用,tag,key,排序,id
来源: https://www.cnblogs.com/ltfxy/p/15858927.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有