【吐血总结】前端开发:一文带你精通Vue.js前端框架(六)

文章目录

    • 前言
    • 1️⃣计算属性
    • 2️⃣监听属性
    • 3️⃣样式绑定
    • 4️⃣总结

前言

上一篇中我们学习了vue.js 的条件语句、循环语句等知识点.,现在让我们接着Vue系列的学习。

Vue中属性与样式绑定在开发中的作用不可或缺。例如实现单位的换算、监听和响应数据的变化及输入事件等,本文将基于实例进行以上知识点的讲解。

在这里插入图片描述


1️⃣计算属性

Vue.js计算属性是一种便捷的声明式方式来定义一个与模板数据绑定相关联的属性。它们可以用于处理和转换数据,并且只有在其依赖的数据发生改变时才会重新求值。

计算属性的定义格式为:

computed: {
  // 计算属性名称
  propertyName: {
    // 计算函数/方法
    get () { /* 计算函数体 */ }
  }
}

其中,propertyName 是计算属性的名称,get() 方法是计算属性的计算函数,它会自动监听数据变化,并在需要时重新计算。

在模板中使用计算属性时,只需像访问普通属性一样访问即可,如:

<div>{{ reversedMessage }}</div>

下面是一个简单的示例,展示了如何定义一个计算属性:

<div id="app">
  <p>{{ message }}</p>
  <p>{{ reversedMessage }}</p>
</div>
var app = new Vue({
  el: '#app',
  data: {
    message: 'Hello World'
  },
  computed: {
    reversedMessage: function() {
      return this.message.split('').reverse().join('')
    }
  }
})

上述代码中,我们定义了一个名为reversedMessage的计算属性。它使用split函数分割message属性中的字母,并使用reverse函数将它们反转,最后使用join函数将它们重新连接成一个字符串。

我们举一个实例,试图将缺无花反转为花无缺:

在这里插入图片描述

由上图可知,我们用计算属性成功实现了字符串的反转

在Vue.js中,计算属性是基于它们的依赖进行缓存的。也就是说,当依赖的数据发生改变时,才会重新求值。这样在多次访问计算属性时,它不需要每次都重新计算,而是直接返回之前缓存的值。


2️⃣监听属性

除了计算属性,Vue.js还提供了一个类似的实例方法watch,用于监听和响应数据的变化。

而用于监听和响应数据变化的属性,就称为监听属性。

watch可以监听一个或多个属性的变化,并在变化发生后执行相应的操作。

下面是一个使用watch方法的示例:

<div id = "app">
    <p style = "font-size:25px;">计数器: {{ counter }}</p>
    <button @click = "counter++" style = "font-size:25px;">点我</button>
</div>
<script type = "text/javascript">
var vm = new Vue({
    el: '#app',
    data: {
        counter: 1
    }
});
vm.$watch('counter', function(nval, oval) {
    alert('计数器值的变化 :' + oval + ' 变为 ' + nval + '!');
});
</script>

在HTML中,有一个id为"app"的容器元素,用于挂载Vue应用。

在Vue实例中,定义了一个名为"counter"的数据属性,初始值为1。

通过双花括号插值语法{{ counter }},将计数器的值渲染到页面上的一个<p>标签中。

通过@click指令绑定到按钮上,当按钮被点击时,计数器的值会自增1。

使用vm.$watch方法监视"counter"属性的变化,并在每次变化时弹出一个警告框,显示计数器的旧值和新值。

回显如下:

在这里插入图片描述

我们也可以用watch实现千米与米的换算:

<div id = "computed_props">
    千米 : <input type = "text" v-model = "kilometers">
     : <input type = "text" v-model = "meters">
</div>
<p id="info"></p>
<script type = "text/javascript">
    var vm = new Vue({
    el: '#computed_props',
    data: {
        kilometers : 0,
        meters:0
    },
    methods: {
    },
    computed :{
    },
    watch : {
        kilometers:function(val) {
            this.kilometers = val;
            this.meters = this.kilometers * 1000
        },
        meters : function (val) {
            this.kilometers = val/ 1000;
            this.meters = val;
        }
    }
    });
    // $watch 是一个实例方法
    vm.$watch('kilometers', function (newValue, oldValue) {
    // 这个回调将在 vm.kilometers 改变后调用
    document.getElementById ("info").innerHTML = "修改前值为: " + oldValue + ",修改后值为: " + newValue;
})
</script>

由下图看到,Vue中监听属性的使用是十分快捷高效的:

在这里插入图片描述


3️⃣样式绑定

Vue.js 提供了多种方式来实现样式绑定。下面是几种常用的样式绑定方法:

1.对象语法:使用对象语法可以根据条件动态地绑定样式。你可以在data中定义一个样式对象,然后将其绑定到元素上。例如,假设有一个名为isActive的数据属性,用于表示元素是否应该处于活跃状态。可以像这样绑定样式:

<div :class="{ active: isActive }"></div>

在上述例子中,如果isActivetrue,则会给div元素添加active类。

2.数组语法:使用数组语法可以根据多个条件同时绑定样式。你可以在data中定义一个包含多个类名的数组,然后将其绑定到元素上。例如,假设有一个名为classNames的数据属性,它是一个包含多个类名的数组。可以像这样绑定样式:

<div :class="classNames"></div>

在上述例子中,classNames数组中的类名都会被添加到div元素上。

3.绑定内联样式对象:我们也可以使用对象语法来绑定内联样式。可以在data中定义一个样式对象,然后将其绑定到元素的style属性上。例如,假设有一个名为customStyle的数据属性,它是一个包含多个样式属性的对象。可以像这样绑定样式:

<div :style="customStyle"></div>

在上述例子中,customStyle对象中的样式属性会应用到div元素的内联样式上。

举个例子:

<div id="app">
    <template>
      <div :style="{ color: textColor, fontSize: fontSize + 'px' }">绑定内联样式对象的实例</div>
    </template>
  </div>

  <script>
    new Vue({
      el: "#app",
      template: `![在这里插入图片描述](https://img-blog.csdnimg.cn/a59efc156f194dcd9139d8ff447660ce.png)

        <div :style="{ color: textColor, fontSize: fontSize + 'px' }">绑定内联样式对象的实例</div>
      `,
      data() {
        return {
          textColor: "blue",
          fontSize: 20
        };
      }
    });
  </script>

在这个例子中,div元素的文本颜色将设置为蓝色(由textColor属性控制),字体大小将根据fontSize属性的值动态计算。

我们来看看页面的回显:

在这里插入图片描述

通过回显可以看到,我们完成了样式绑定。


4️⃣总结

以上为前端开发:一文带你精通Vue.js前端框架系列(六),带领读者掌握计算属性、监听属性及样式绑定。

前端开发系列将持续更新,读者可订阅专栏持续学习。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vue3 setup() 高级用法

文章目录 前言一、选项式API 和 组合式API 区别用一张图告诉你它们的区别&#xff1a; 二、setup 具体怎么用&#xff1f;2.1、setup 什么时候执行&#xff1f;2.2、setup 数据和方法如何使用&#xff1f;2.3、setup 内部有 this 吗&#xff1f;2.4、setup 内钩子函数如何使用&…

进博会再现上亿大单 EZZ携手HIC海橙嗨选签署2024年度合作备忘录

正在举行的第六届中国国际进口博览会上&#xff0c;再现上亿大单。11月6日&#xff0c;在澳大利亚新南威尔士州政府代表的见证下&#xff0c;澳交所基因组龙头上市公司EZZ生命科学和中国跨境社交电商龙头HIC海橙嗨选签署2024合作备忘录&#xff0c;在未来的一年&#xff0c;EZZ…

分类预测 | Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多输入分类预测

分类预测 | Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多输入分类预测 目录 分类预测 | Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多输入分类预测分类效果基本描述程序设计参考资料 分类效果 基本描述 Matlab实现PSO-GRU粒子群算法优化门控循环单元的数据多…

【算法每日一练]-单调队列(保姆级教程 篇2)#琪露诺 #选数游戏 #寻找段落

最后一期单调队列了啊 目录 题目&#xff1a;琪露诺 思路&#xff1a; 题目&#xff1a;选数游戏 思路&#xff1a; 题目&#xff1a;寻找段落 思路&#xff1a; 之前做的都是连续的长度区间求最值&#xff0c;今天体验一下不连续的区间。 然后就是要注意维护单调队列时…

说说你对immutable的理解?如何应用在react项目中?

一、是什么 Immutable,不可改变的,在计算机中,即指一旦创建,就不能再被更改的数据 对 Immutable对象的任何修改或添加删除操作都会返回一个新的 Immutable对象 Immutable 实现的原理是 Persistent Data Structure(持久化数据结构): 用一种数据结构来保存数据当数据被修…

1.jvm基本知识

目录 概述jvm虚拟机三问jvm是什么&#xff1f;java 和 jvm 的关系 为什么学jvm怎么学习为什么jvm调优?什么时候jvm调优调优调什么 结束 概述 相关文章在此总结如下&#xff1a; 文章地址jvm类加载系统地址双亲委派模型与打破双亲委派地址运行时数据区地址 jvm虚拟机三问 j…

OpenCV:图像矫正与仿射变换

人工智能的学习之路非常漫长&#xff0c;不少人因为学习路线不对或者学习内容不够专业而举步难行。不过别担心&#xff0c;我为大家整理了一份600多G的学习资源&#xff0c;基本上涵盖了人工智能学习的所有内容。点击下方链接,0元进群领取学习资源,让你的学习之路更加顺畅!记得…

Java_常用API

API(全称Application Programming Interface:应用程序编程接口) String 常用方法 注意事项 每一次试图改变字符串对象都产生了新的字符串对象 ArrayList 常用方法 ATM系统 01系统架构搭建、欢迎页设计 02开户功能实现 03登录功能实现 04操作页展示、查询账户、退出账户 05存…

笔尖笔帽检测1:笔尖笔帽检测数据集(含下载链接)

笔尖笔帽检测1&#xff1a;笔尖笔帽检测数据集(含下载链接) 目录 笔尖笔帽检测1&#xff1a;笔尖笔帽检测数据集(含下载链接) 1. 前言 2. 手笔检测数据集 &#xff08;1&#xff09;Hand-voc1 &#xff08;2&#xff09;Hand-voc2 &#xff08;3&#xff09;Hand-voc3 …

Allegro层叠中的Etch Factor-铜皮的腐蚀因子如何计算

Allegro层叠中的Etch Factor-铜皮的腐蚀因子如何计算 在用Allegro进行PCB设计的时候,Cross-section中需要填入对应的信息,一般填入每层的厚度即可,如下图 当PCB需要进行仿真分析的时候,Etch-Factor这个值是必须要填写的,如下图 目前看到的都是90这个值,这是一个理论值。 …

iOS群控手机App的开发难点是什么?

随着智能手机的普及&#xff0c;手机App已经成为我们生活中不可或缺的一部分&#xff0c;在众多手机操作系统中&#xff0c;iOS系统因其封闭性、安全性和流畅性而备受用户青睐&#xff0c;然而&#xff0c;开发一款针对iOS系统的手机App却并非易事。 一、开发语言与框架 iOS系…

【IDE】【实战系列】掌握这些技巧发现阅读源码不过如此简单

文章目录 IDE 版本前言IDE Debug主界面介绍字段断点&#xff08;field breakpoints&#xff09;使用方式配置EnabledSuspendLog 行断点&#xff08;line breakpoints&#xff09;使用方式配置方式 方法断点&#xff08;method breakpoints&#xff09;使用方式配置方式 异常断点…

datax 搭建使用

文章目录 datax 环境搭建使用一、解压文件二、配置 json 文件三、执行命令 datax 环境搭建使用 用于全量同步 一、解压文件 将包上传至服务器 输入命令&#xff1a; tar -zxvf datax.tar.gz -C /opt/module/ 将包 解压到 /opt/module 目录 解压完之后&#xff0c;不需要任何…

在线教育与跨境电商:数字时代的知识传播

随着数字技术的不断发展和全球互联网的普及&#xff0c;在线教育和跨境电商在数字时代崭露头角&#xff0c;共同推动了知识的全球传播。 这两个领域的结合为学生、教育者和知识提供者创造了新的机遇和可能性&#xff0c;同时也带来了一系列有趣的挑战。本文将深入探讨在线教育…

【01】Istio-1.17 部署

1.1 部署Istio控制平面 部署方法 istioctl istio的专用管理工具&#xff0c;支持定制控制平面和数据平面通过命令行的选项支持完整的IstioOperator API命令行各选项可用于单独设置&#xff0c;以及接收包含IstioOperator自定义资源(CR)的yaml文件 Istio Operator Istio相关的自…

linux 安装 mini conda,linux下安装 Miniconda

下载地址 https://docs.conda.io/projects/miniconda/en/latest/index.html 安装conda mkdir -p ~/miniconda3 wget https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh -O ~/miniconda3/miniconda.sh bash ~/miniconda3/miniconda.sh -b -u -p ~/mini…

数据结构上机实验——图的实现(以无向邻接表为例)、图的深度优先搜索(DFS)、图的广度优先搜索(BFS)

文章目录 数据结构上机实验1.要求2.图的实现&#xff08;以无向邻接表为例&#xff09;2.1创建图2.1.1定义图的顶点、边及类定义2.1.2创建无向图和查找2.1.3插入边2.1.4打印函数 2.2图的深度优先搜索&#xff08;DFS&#xff09;2.3图的广度优先搜索&#xff08;BFS&#xff09…

C/C++ #define与编译器的预处理

文章目录 预处理#define新版本特性旧版本特性#define除了定义明示常量的其他用途 #define的组成#define本身&#xff1a;预处理指令宏替换列表或替换体宏展开 参考资料 预处理 在预处理之前&#xff0c;编译器必须对该程序进行一些翻译处理。首先&#xff0c;编译器 把源代码中…

WampServer下载安装并结合内网穿透实现本地服务的公网访问

文章目录 前言1.WampServer下载安装2.WampServer启动3.安装cpolar内网穿透3.1 注册账号3.2 下载cpolar客户端3.3 登录cpolar web ui管理界面3.4 创建公网地址 4.固定公网地址访问 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的 人工智能学习网站&#xff0c;…

【Kettle实战】数据分批处理及参数化传递子作业任务

对于大表操作&#xff0c;本来离线数据需要分批处理&#xff0c;刚开始只会用具体日期去做&#xff0c;通过复制多分转换和作业来处理。当日期范围大了后&#xff0c;这是个苦力活儿&#xff0c;kettle里面有参数化传递功能&#xff0c;多动手实操&#xff0c;懂得灵活变通自然…