vue计算属性、内容分发

计算属性可以想象为缓存

 在调用方法时,每次都需要进行计算,既然有计算过程则必定产生系统开销,那如果这个结果时不经常变化的呢?此时就

可以考虑将这个结果缓存起来,采用计算属性可以很方便的做到这一点,计算属性的主要特性就是为了将不经常变化的计算结果进行缓存,

以节省我们的系统开销

计算属性一般写在computed属性中

上代码

<div id="vue">
    <p>{{currentTime2}}</p>

</div>

<!--    到入vue.js-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script>
    var vm = new Vue({
        el: "#vue",
        data: {
            message: "hello,kuangshen"
        },
        methods: {
            currentTime1: function () {
                return Date.now();   //返回一个时间戳
            }
        },
        computed:{  //计算属性   methods和computed中的方法名不能重复
            //在调用conputed的方法时,实际调用的是一个属性
            //在运行时,如果内容没有变化,其中的内容不会再刷新,如果有变化时,则会更新原有数据
            currentTime2: function () {
                return Date.now();   //返回一个时间戳
            }
        }

    })
</script>

 

接下来开始说插槽,也就是slot属性

首先引入场景

假如我们有这样一串代码

    <P>编程语言</P>
    <ul>
        <li>Java</li>
        <li>C</li>
        <li>C++</li>
        <li>Python</li>
    </ul>

我们呢,想要将p标签里的内容以及li标签里的内容从vue属性中读取

那么问题就来了,结合我们前面所学习的内容,li标签里的内容完全可以用for循环遍历出来,而p标签中的内容也可以通过绑定数据来实现

但是我们如果想用一个标签来实现所有的操作

这就有所困难了,为了实现我们的目的,我们首先要发现我们的困难,因为总的三个标签中的内容,ul标签中的内容是不需要改变的

因此,我们可以将整个弄成一个模板,然后将p标签与li标签中的内容换成一个插口,然后将我们想要的数据放到这个插口里,如此便实现了我们的目的

如此以来,上代码

<div id="app">
    <tudo>
        <todo-tille :tille="todotille" slot="todo-tille"></todo-tille>
        <todo-items v-for="item in todoitems" :item="item" slot="todo-items"></todo-items>
    </tudo>
</div>


<!--    到入vue.js-->
<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14"></script>
<script>
    Vue.component("todo",{
        template:'' +
            '<div>' +
                '<slot name="todo-tille"></slot>' +
                    '<ul>' +
                        '<slot name="todo-items"></slot>' +
                    '</ul>' +
            '</div>'
    })
    Vue.component("todo-tille",{
        props:['tille'],
        template: '<div>{{tille}}</div>'
    }),
    Vue.component("todo-items", {
        props:['item'],
        template: '<li>{{item}}</li>'
    })
    var vm = new Vue({
        el:"#app", //绑定id
        data:{
            todotille:'汇编语言',
            todoitems:['Java','Python','C','C++']
        }
    });

</script>

从代码中我们可以看到

我们设计了三个模板,然后将两个模板嵌套到了一个模板中,也就是这

 

 与slot标签绑定的方式就是将其中设计一个name属性,然后在把我们的模板实例化的标签中加上slot属性,将slot属性等于我们之前在slot标签中

设置的name属性

 

 

posted @ 2023-04-22 20:45  软工小蜗牛  阅读(16)  评论(0)    收藏  举报