Vue实例的基本属性、Vue的内置指令、计算属性、状态监听属性、过滤器

导读:本篇文章讲解 Vue实例的基本属性、Vue的内置指令、计算属性、状态监听属性、过滤器,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

一、Vue实例的属性

1. MVVM架构:Model —- View —- ViewModel 实现数据的双向绑定

2. Vue实例:Vue对象,本质是一个ViewModel

3. Vue实例的属性

​ (1)el:是element的简写,指定Vue实例绑定的根元素。可以是id,也可以是class。必须的

​ (2)data:对Vue实例的变量进行初始化。

​ (3)methods:定义vue实例的方法

二、Vue的内置指令

1. 插值表达式:{{ 表达式 }} 实现数据的单向绑定

2. v-text

3. v-html

4. v-model:将input标签的value属性值绑定到变量上。实现双向绑定

5. v-bind:简写方式是:“属性名=变量名”

6. v-on:绑定事件,并执行相应的处理。简写方式是 “ @事件名=事件处理函数名 ”

三、Vue实例的计算属性:computed

        computed计算属性:计算属性结果会被缓存起来,当依赖的响应式属性发生变化时,才会重新计算,返回最终结果。

    <script src="../js/vue.js"></script>

<body>
    <div id="app">
        <p>总价:{{ totalPrice }}</p>
        <p>单价:{{ price }}</p>
        <p>数量:{{ num }}</p>
        <!-- <button @click=" num==0?0:num-- ">减少</button>
        <button @click=" num++ ">增加</button> -->
        <button @click=" sub ">减少</button>
        <button @click=" add ">增加</button>
    </div>

    <script>
        const vm = new Vue({
            el:'#app',
            data:{
                price:20,
                num:0,
            },
            methods:{
                add(){
                    this.num++
                },
                sub(){
                    this.num==0?0:this.num--
                }
            },
            computed:{
                totalPrice(){//本质是属性
                    return this.num * this.price
                }
            }
        })
    </script>
</body>

四、Vue实例的状态监听属性:watch

         watch:可以对元素的值的变化进行跟踪

    <script src="../js/vue.js"></script>

<body>
    <div id="app">
        <label>
            城市名:<input type="text" v-model="cityName">
        </label>
    </div>

    <script>
        const vm = new Vue({
            el:'#app',
            data:{
                cityName:'shanghai'
            },
            watch:{
                cityName(newValue,oldValue){//定义监听器:用来监控变量的值的变化
                      console.log(newValue,oldValue);
                }
            }
        })
    </script>

五、Vue实例的过滤器:filters

       filters:可以直接操作数据,对数据按要求进行过滤

1. 作用

​ (1)文本格式化

​ (2)对数组元素进行筛选、排序

2. 注意:Vue2.0版本后内置过滤器被废除,用户若要使用需自己编写

3. 使用的方式

​ (1)插值表达式中通过管道符“|”实现:{{ 文本或数组 | 过滤器 }}

​ (2)在v-bind中通过管道符“|”实现:

<div v-bind:id= "myId | 过滤器 "></div>

        强调:过滤器的本质是函数

4. 根据作用范围的不同,分为全局过滤器和局部过滤器

​ (1)全局过滤器的定义:

        Vue.filter(id,[definition])

       ​ 第一个参数id:表示过滤器的名称(过滤器的唯一标识)

​        第二个参数:是一个函数对象,定义了过滤器的具体实现过程

    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="app">
        <input type="text" v-model="message">
        <p>{{ message | Cate }}</p>
    </div>

    <script>
        // 定义全局的过滤器:Vue.filter(id,fn)
        Vue.filter('Cate',function(value){
            if(!value)return ''   //若value为空,返回空串
            value = value.toString()  //若value不为空,将其转换为字符串
            return value.toUpperCase()  //将value中的所有字母转换为大写
        })
        const vm = new Vue({
            el:'#app',
            data:{
                message:'javascript'
            },
        })
    </script>
</body>

(2)局部过滤器的定义:是在Vue实例的选项对象中使用filters选项来注册。只在注册的Vue实例中有效

    <script src="../js/vue.js"></script>

<body>
    <div id="app">
        <input type="text" v-model="message">
        <p>{{ message | Cate }}</p>
    </div>

    <script>
        const vm = new Vue({
            el:'#app',
            data:{
                message:'javascript'
            },
            filters:{ //定义局部的过滤器,只在实例对象中起作用
                Cate:function(value){
                    if(!value) return "" //若value为空,返回空串
                    value = value.toString()//若value不为空,将其转换为字符串
                    return value.toUpperCase()//将value中的所有字母转换为大写
                }
            }
        })
    </script>
</body>

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由半码博客整理,本文链接:https://www.bmabk.com/index.php/post/79747.html

(0)

相关推荐

半码博客——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!