vue 笔记 实例方法和计算属性还有过滤器

vue实例方法语法

methods:{

方法名:function(){ }

简化写法:方法名(){}

}

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js">
</script>
<div id="app">
    a:<input type='text' v-model="a" />+ b:
    <input type='text' v-model='b'>= {{sum()}}
</div>
<script>
    new Vue({
        el: '#app',
        data() {
            return {
                a: "",
                b: "",
            }
        },
        methods: {
            sum() {
                return parseInt(this.a * 1) + parseInt(this.b * 1)
            }
        }
    })
</script>

计算属性

模板内使用表达式非常便利,但是如果在模板中放入太多的逻辑会让模板过重,且难以维护,所以对于任何复杂逻辑,都应当使用计算属性

computed:{

方法名字:function(){}

简写:方法名字(){}

}

翻转字符串

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js">
</script>
<div id="app">
    <p>原字符串: {{ msg }}</p>
    <p>计算属性反转字符串: {{ rmovemsg }}</p>
    <p>实例方法翻转字符串:{{add()}}</p>
</div>
<script>
    new Vue({
        el: '#app',
        data: {
            msg: 'Hello,world!'
        },
        computed: {
            rmovemsg: function() {
                return this.msg.split("").reverse().join('');
            }
        },
        methods: {
            add() {
                return this.msg.split("").reverse().join('');
            }
        }
    })
</script>

过滤器

过滤器,就是将数据被渲染到视图之前进行格式化处理,而不会修改作用域中原有的数据

原则是:左值右量(变量也可以不写)

语法

filtere:{

过滤器:function(参数1,参数2){} 

过滤器(参数1,参数2){}

Vue.filter()

说明:定义过滤器时,必须声明参数,并且参数1是固定的,指的是要操作的数据,剩余的参数是调用过滤器时传递进来的

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js">
</script>
<div class="test">
    {{messaga | capitalize}} {{message | capitalize}} {{messagb | capitalize}}
</div>
<script type="text/javascript">
    var myVue = new Vue({
        el: ".test",
        data: {
            messaga: "abc",
            message: "def",
            messagb: "ghi"
        }
    })
</script>

简写购物车

<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js">
</script>
<div id="app">
    <ul>
        <li v-for="good of goods">
            <input type="checkbox" @click="checkbox(good)" />
            <span>商品名称:{{good.goodname}}</span>
            <input type="button" value="-" @click="changeNum(0,good)" />
            <input type="number" v-bind:value="good.num || 0" />
            <input type="button" value="+" @click="changeNum(1,good)" />
            <span>单价:{{good.price}}</span>
            <span>小计:{{((good.num*good.price)?(good.num*good.price):0)|price}}</span>
        </li>
    </ul>
    <p>总金额:{{allPrice | price}}</p>
</div>
<script>
    new Vue({
        el: '#app',
        data: {
            goods: [{
                'id': 0,
                'goodname': '肥皂',
                'price': 4.3
            }, {
                'id': 1,
                'goodname': '洗发水',
                'price': 34
            }, {
                'id': 2,
                'goodname': '洗衣粉',
                'price': 7.3
            }],
            goodnumber: null,
        },
        methods: {
            // 改变数量
            changeNum(arg1, item) {
                if (!item.num) {
                    // $set是添加值
                    this.$set(item, 'num', 0);
                }
                // 判断为真的时候为增加的方法,否则为假的方法
                if (arg1) {
                    item.num++;
                } else {
                    item.num--;
                }
            },
            // 设置选中与不选中
            checkbox(item) {
                if (item.active) {
                    this.$set(item, 'active', false);
                } else {
                    this.$set(item, 'active', true);
                }
                console.log(item);
            }
        },
        filters: {
            price(arg) {
                return arg.toFixed(2) + '元';
            }
        },
        computed: {
            // 计算总价
            allPrice() {
                var result = 0;
                for (var i in this.goods) {
                    if (this.goods[i].active) {
                        result += this.goods[i].price * this.goods[i].num;
                    }
                }
                return result;
            }
        }
    })
</script>

计算属性和实例方法区别:

计算属性有缓存,而实例方法没有缓存

使用计算属性的时候,{{计算属性名}}

使用实例方法时,{{方法名()}}

参数的传递 实例方法可以传递参数 但计算属性不能

计算属性和实例方法共同点:

数据的监听 计算属性和实例 都会监听原数据(数据改变 逻辑重新执行)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue过滤器计算属性Vue.js中的两个核心选项。过滤器用于对数据进行格式化或处理,计算属性用于根据已有的数据计算出新的数据。 过滤器可以在模板中使用,通过管道符(|)将数据传递给过滤器函数进行处理。过滤器可以是局部过滤器或全局过滤器。局部过滤器定义在组件中的filters选项中,而全局过滤器可以在任何地方使用。过滤器函数接收一个参数,即要处理的数据,然后返回处理后的结果。过滤器函数必须有返回值,以便在模板中使用过滤器时获取到结果。\[2\]例如,可以定义一个名为upper的过滤器,将传入的字符串转换为大写字母。 计算属性是在Vue实例中定义的属性,它根据已有的数据计算出新的数据。计算属性可以在模板中使用,通过在模板中使用计算属性的名称来获取计算后的值。计算属性的值会被缓存,只有在依赖的数据发生变化时才会重新计算。计算属性可以包含一个getter函数和一个setter函数,用于获取和设置计算属性的值。\[1\]例如,可以定义一个名为fullName的计算属性,根据firstName和lastName的值计算出完整的姓名。 总结起来,过滤器用于对数据进行格式化或处理,而计算属性用于根据已有的数据计算出新的数据。它们都可以在模板中使用,但过滤器是对数据进行处理,而计算属性是根据已有的数据计算出新的数据。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* [Vue 基础语法之计算属性(computed)、侦听器(watch)、过滤器(filters)](https://blog.csdn.net/p445098355/article/details/121596111)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Vue过滤器计算属性以及生命周期](https://blog.csdn.net/sj1255897381/article/details/107400254)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值