【Vue】Vue扫盲(三)计算属性和监听器

news2025/1/13 9:46:01

【Vue】Vue扫盲(一)事件标签、事件修饰符:@click.prevent @click.stop @click.stop.prevent、按键修饰符、及常用指令

【Vue】Vue扫盲(二)指令:v-for 、v-if、v-else-if、v-else、v-show

文章目录

    • 1、 计算属性(computed)
    • 2、监听器 watch
    • 3、过滤器(局部过滤器、全局过滤器)

1、 计算属性(computed)

某些结果是基于页面上之前的数据实时计算出来的, 我们可以利用计算属性。 来完成
示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>计算属性和监听器</title>
</head>
<body>
    <div id="app" style="border: 1px red; margin: auto;">
        <ul>
            <li>西游记,价格{{xyjPrive}},数量:<input type="number" v-model="xyjNum"/></li>
            <li>水浒传,价格{{shzPrice}},数量:<input type="number" v-model="shzNum"/></li>
            <li>总价{{totalPrice}}</li>

            
        </ul>

    </div>


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

       let vm = new Vue({
            el:"#app",
            data:{
                xyjPrive:99.98,
                shzPrice:98,
                xyjNum:1,
                shzNum:1
                
            },
            methods: {
                 
            },
            computed:{
                totalPrice(){
                    return this.xyjPrive*this.xyjNum+this.shzPrice*this.shzNum;
                }
            }
        })

    </script>
</body>
</html>

结果1:
在这里插入图片描述
结果2:
在这里插入图片描述

2、监听器 watch

watch 可以让我们监控一个值的变化。 从而做出相应的反应。
示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>计算属性和监听器</title>
</head>
<body>
    <div id="app" style="border: 1px red; margin: auto;">
        <ul>
            <li>西游记,价格{{xyjPrive}},数量:<input type="number" v-model="xyjNum"/></li>
            <li>水浒传,价格{{shzPrice}},数量:<input type="number" v-model="shzNum"/></li>
            <li>总价{{totalPrice}}</li>
            提示信息:{{msg}}
            
        </ul>

    </div>


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

       let vm = new Vue({
            el:"#app",
            data:{
                xyjPrive:99.98,
                shzPrice:98,
                xyjNum:1,
                shzNum:1,
                msg:""
                
            },
            methods: {
                 
            },
            computed:{
                totalPrice(){
                    return this.xyjPrive*this.xyjNum+this.shzPrice*this.shzNum;
                }
            },
            watch:{ //watch可以让我们监控一个值的变化,从而做出反应
                xyjNum:function(newVal,oldVal){ //同等写法:xyjNum(newVal,oldVal)
                    if(newVal>=3){
                        this.msg="西游记库存没有更多了";
                         this.xyjNum=3;
                    }else{
                        this.msg="";
                    }
                }
            }
        })

    </script>
</body>
</html>

效果1:
西游记的数量不能超过3,如果超过3,则无法在增加,一直是三。并给出提示库存超出
在这里插入图片描述

在这里插入图片描述

效果2:
在这里插入图片描述
在这里插入图片描述

3、过滤器(局部过滤器、全局过滤器)

过滤器不改变真正的data, 而只是改变渲染的结果, 并返回过滤后的版本。 在很多不同的
情况下, 过滤器都是有用的, 比如尽可能保持 API 响应的干净, 并在前端处理数据的格式。

示例: 展示用户列表性别显示男女

  • 下面的 genderFilter 一个局部过滤器,只能在当前的Vue监听的视图中使用
  • gFilter 是一个全局过滤器,在全局都可以用
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>过滤器</title>
</head>

<body>

    <!-- 过滤器通常用来处理文本格式化的操作,过滤器可以用在两个地方,双花括号插值和v-bind表达式 -->
    <div id="app">
        <ul>
            <li v-for="user in userList" :key="user.id">
                {{user.id}}==>{{user.name}}==>{{user.gender}}==>
                {{user.gender ==1?"男":"女"}} <!-- 简单的可以通过三目运算符来完成转换,如果复杂的则通过过滤器进行转化 -->
                ====使用局部过滤器后的结果:{{user.gender|genderFilter}}
                ====》 使用全局过滤器后的结果:{{user.gender|gFilter}}
            </li> <!-- 上面的{{user.gender|genderFilter}} 中的 | 是管道符的作用 ,是把前面user.gender的值传给了 后面的genderFliter中进行处理,
            并返回一个值-->
        </ul>

    </div>


    <script src="../node_modules/vue/dist/vue.js"></script>
    <script>
        //第一个参数:过滤器名字,第二个参数是函数体(真正的处理逻辑)
        Vue.filter("gFilter",function(val){
            if (val == 1) {
                        return "男~~~";
                    } else {
                        return "女~~~";
                    }
        })

        let vm = new Vue({
            el: "#app",
            data: {
                userList: [
                    { id: 1, name: 'jacky', gender: 1 },
                    { id: 2, name: 'peter', gender: 0 }
                ]
            },
            methods: {

            },
            filters: {
                //由于这个过滤器写在单个的Vue实例中,所以叫做局部过滤器,我们还有全局过滤器一说
                genderFilter(val) {
                    if (val == 1) {
                        return "男";
                    } else {
                        return "女";
                    }
                }
            }
        })

    </script>
</body>

</html>

结果: 1转换成了男 2 转换成了女
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2204608.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

史上最全C语言static与extern指南

一、引言 在C语言中&#xff0c;static和extern关键字是非常重要的&#xff0c;它们分别用于控制变量的作用域和生命周期&#xff0c;以及变量和函数的定义和声明。理解这些关键字如何工作对于编写清晰、高效的代码至关重要。 二、static关键字 static关键字用于声明变量或函…

背靠背 丢包问题分析

存在一个设计需求&#xff0c;原始数据不足满字节有效的&#xff0c;要将数据整体右移对齐后输出。 整体移位后&#xff0c;存在eop 前移一拍情况。 实际分析时&#xff0c;因为是做数据裁剪&#xff0c;不会出现带宽膨胀问题&#xff08;1拍需要多拍出&#xff09;。 最…

关于摩托车一键启动无钥匙进入、智能科技创新

摩托车一键启动无钥匙进入功能 一、工作原理 摩托车的一键启动无钥匙进入功能采用了世界最先进的RFID无线射频技术和最先进的车辆身份编码识别系统&#xff0c;率先应用小型化、小功率射频天线的开发方案&#xff0c;并成功融合了遥控系统和无钥匙系统&#xff0c;沿用了传统…

基于Springboot+Vue的线上一流课程教学辅助系统 (含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 在系统…

01 为什么要学习数据结构与算法

为什么要学习数据结构与算法 一、问题提出 ​ 最早计算机的设计初衷主要用于军事上枪炮的弹道计算和火力表的测试&#xff0c;后来更多的用于科学计算&#xff0c;即数值类的计算&#xff0c;而现在&#xff0c;计算机深入到日常生活的各个方面&#xff0c;其计算的数据早已从…

【论文阅读】Cross Attention Network for Few-shot Classification

用于小样本分类的交叉注意力网络 引用&#xff1a;Hou, Ruibing, et al. “Cross attention network for few-shot classification.” Advances in neural information processing systems 32 (2019). 论文地址&#xff1a;下载地址 论文代码&#xff1a;https://github.com/bl…

畅阅读微信小程序+ssm论文源码调试讲解

2 系统开发环境 2.1微信开发者工具 微信开发者工具现在已经被小程序开发团队开发运行&#xff0c;目前微信开发者工具任然在不断的完善中&#xff0c;在开发小程序时经常要不断的更新。可以使用微信扫码登陆开发者工具&#xff0c;开发者工具将使用这个微信帐号的信息进行小程…

【含文档】基于Springboot+Vue的母婴全程服务管理系统(含源码+数据库+lw)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统定…

CSS @规则(At-rules)系列详解___@charset规则使用方法

CSS 规则(At-rules)系列详解 ___charset规则使用方法 本篇目录&#xff1a; 零、时光宝盒 一、charset规则定义和用法 二、CSS charset语法 三、charset 使用方法例子 1、正确使用方法 2、无效的&#xff0c;错误的使用方法 零、时光宝盒 &#xff08;https://blog.csd…

解决 IntelliJ IDEA 运行时 “Command line is too long“ 问题

文章目录 文章标题&#xff1a;解决 IntelliJ IDEA 运行时 "Command line is too long" 问题简介问题描述解决方案代码示例代码示例1&#xff1a;使用JAR Manifest代码示例2&#xff1a;使用Classpath File代码示例3&#xff1a;优化项目依赖 结论进一步的资源 文章标…

【算法】滑动窗口(续)

一、将x减到0的最小操作数 1658. 将 x 减到 0 的最小操作数 - 力扣&#xff08;LeetCode&#xff09; 给你一个整数数组 nums 和一个整数 x 。每一次操作时&#xff0c;你应当移除数组 nums 最左边或最右边的元素&#xff0c;然后从 x 中减去该元素的值。请注意&#xff0c;需要…

如何使用 Hailuo AI 生成视频

在这个科技飞速发展的时代&#xff0c;人工智能已经成为创意领域的重要工具。Hailuo AI 是一个强大的平台&#xff0c;可以帮助你将文字描述转化为高质量的视频。以下是详细的步骤&#xff0c;教你如何使用 Hailuo AI 生成视频。 第一步&#xff1a;访问 Hailuo AI 网站 首先…

第十四章 Java多线程--阻塞队列--SynchronousQueue

目录 一、SynchronousQueue基础概念 主要特点 使用场景 示例代码 二、SynchronousQueue深入了解 1 SynchronousQueue介绍 2 SynchronousQueue核心属性 3 SynchronousQueue的TransferQueue源码 3.1 QNode源码信息 3.2 transfer方法实现 3.3 tansfer方法流程图 一、Sy…

【C++堆(优先队列)】1834. 单线程 CPU|1797

本文涉及知识点 C堆(优先队列) LeetCode1834. 单线程 CPU 给你一个二维数组 tasks &#xff0c;用于表示 n​​​​​​ 项从 0 到 n - 1 编号的任务。其中 tasks[i] [enqueueTimei, processingTimei] 意味着第 i​​​​​​​​​​ 项任务将会于 enqueueTimei 时进入任务…

QStandardItemModel的role

QStandardItemModel定义了一些标准的角色&#xff0c;而QAbstractItemModel允许自定义角色。以下是一些常见的数据角色&#xff1a;1. **Qt::DisplayRole**&#xff1a;这是最基本的角色&#xff0c;用于显示在视图中的文本。当一个单元格被绘制时&#xff0c;通常会查询这个角…

Go 语言应用开发:从入门到实战

Go 语言应用开发&#xff1a;从入门到实战 引言 Go&#xff08;Golang&#xff09;是由 Google 开发的一种开源编程语言&#xff0c;设计初衷是提高编程效率&#xff0c;尤其是在高并发场景下表现出色。Go 语言以其简洁、易学、高效并发的特性&#xff0c;逐渐成为开发者的首…

<Project-8.1.1 pdf2tx-mm> Python 调用 ChatGPT API 翻译PDF内容 历程心得

原因 用ZhipuAI&#xff0c;测试用的PDF里&#xff0c;有国名西部省穆斯林&#xff0c;翻译结果返回 “系统检测到输入或生成内容可能包含不安全或敏感内容&#xff0c;请您避免输入易产生敏感内容的提 示语&#xff0c;感谢您的配合” 。想过先替换掉省名、民族名等&#xff…

DM8数据库用户和表空间管理

1 说明 DM8用户管理和表空间管理常用的管理命令&#xff0c;包括创建、修改和查看信息操作等。 2 用户管理 2.1 创建用户 创建一个用户lu9up&#xff0c;密码为"admin2024."&#xff0c;未制定表空间&#xff0c;使用默认的表空间main。 SQL> create user lu…

银河麒麟桌面操作系统V10:解决激活时“无法获取硬件信息(错误码#0017)”问题

银河麒麟桌面操作系统V10&#xff1a;解决激活时“无法获取硬件信息&#xff08;错误码#0017&#xff09;”问题 1、问题描述2、问题解决方法步骤一&#xff1a;打开终端步骤二&#xff1a;删除/etc/.kyhwid文件步骤三&#xff1a;重新激活系统总结 &#x1f490;The Begin&…

【Ubuntu】在Ubuntu上安装IDEA

【Ubuntu】在Ubuntu上安装IDEA 零、前言 最近换了Ubuntu系统&#xff0c;但是还得是要写代码&#xff0c;这样就不可避免地用到IDEA&#xff0c;接下来介绍一下如何在Ubuntu上安装IDEA。 壹、下载 这一步应该很容易的&#xff0c;直接打开IDEA的下载页面&#xff0c;点击下…