VUE 数组更新

2018-06-24 01:03:40来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

1、数据方法分类:

(1)原数组改变

push
pop
unshift
shift
reverse
sort
splice

(2)原数组未变,生成新数组

slice
concat
filter

map

 

对于使原数组变化的方法,可以直接更新视图。

对于原数组未变的方法,可以使用新数组替换原来的数组,以使视图发生变化。

示例代码:

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

    <head>
        <meta charset="UTF-8" />
        <title>vue示例</title>
    </head>

    <body>
        <div id="app">
            <ul>
                <template v-for="book in books">
                    <li>书名:{{book.name}}</li>
                    <li>作者:{{book.author}}</li>
                </template>
            </ul>
        </div>
        <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script>
        <script type="text/javascript">
            var app = new Vue({
                el: '#app',
                data: {
                    books: [{
                            name: 'vuejs',
                            author: 'a'
                        },
                        {
                            name: 'js高级',
                            author: 'b'
                        },
                        {
                            name: 'java',
                            author: 'c'
                        }
                    ]
                }
            });
            //直接可以使得视图改变
            //app.books.push({name: 'c++',author: 'd'});
            //需要更新原数组
            app.books = app.books.concat([{name: 'c++',author: 'd'}]);
            
        </script>
    </body>

</html>

注意:以下不会触发视图的更新。

(1)通过索引直接设置项。

(2)修改数组长度,app.books.length=1

若不想改变原数组,可以使用计算属性来过滤数组,如:

 

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

    <head>
        <meta charset="UTF-8" />
        <title>vue示例</title>
    </head>

    <body>
        <div id="app">
            <ul>
                <template v-for="book in filterBooks">
                    <li>书名:{{book.name}}</li>
                    <li>作者:{{book.author}}</li>
                </template>
            </ul>
        </div>
        <script src="https://cdn.bootcss.com/vue/2.5.9/vue.min.js"></script>
        <script type="text/javascript">
            var app = new Vue({
                el: '#app',
                data: {
                    books: [{
                            name: 'vuejs',
                            author: 'a'
                        },
                        {
                            name: 'js高级111',
                            author: 'b'
                        },
                        {
                            name: 'java33333',
                            author: 'c'
                        }
                    ]
                },
                computed:{
                    filterBooks:function(){
                        return this.books.sort(function(a,b){
                            return a.name.length>b.name.length?1:-1
                        })
                    }
                }
            });
            
        </script>
    </body>

</html>

 

上述代码是按照书的名字由短到长排序。这个不会修改原数组。

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:.10-浅析webpack源码之graceful-fs模块

下一篇:.11-浅析webpack源码之Storage模块