Vue详细入门(语法【三】)

今天滴的学习目标!!!

  • Vue组件是什么?
  • 组件的特性和优势
  • Vue3计算属性
  • Vue3监听属性

  在前面Vue详细入门(语法【一】——【二】)当中我们学习了Vue有哪些指令,它的核心语法有哪些?今天我们学习Vue组件是什么?组件的特性和优势,Vue3计算属性,Vue3监听属性 (^-^)

Vue组件是什么?

  首先我们要了解Vue组件是什么?是用来干什么的?

  Vue组件是Vue.js框架中的基础构建块,它们允许开发者将UI分割成可复用的部分,每个部分都包含自己的逻辑、模板和样式。组件使得大型应用的开发变得更加模块化和易于管理。

Vue组件的用途

  1. 代码复用:通过创建组件,你可以将UI的某个部分抽象出来,然后在不同的地方重复使用它,而不需要每次都重写相同的代码。
  2. 模块化:组件使得应用的结构更加清晰,每个组件都负责自己的功能,这有助于开发者理解和维护代码。
  3. 可维护性:由于组件是独立的,因此可以单独测试、调试和更新,而不会影响到其他部分。
  4. 可扩展性:组件可以通过插槽(slots)、事件(events)和属性(props)等方式进行扩展和自定义,以适应不同的使用场景。

Vue组件的基本结构
一个Vue组件通常由以下部分组成:

  1. 模板(template):定义了组件的HTML结构。
  2. 脚本(script):包含了组件的逻辑,如数据、方法、计算属性等。
    样式(style):定义了组件的CSS样式,可以使用scoped属性来确保样式只作用于当前组件

Vue组件的示例代码
下面是一个简单的Vue组件示例,全局组件实例:

展示了如何创建一个Vue应用,定义一个全局组件,并将该组件挂载到DOM中的一个元素上
在这里插入图片描述
接下来我们再注册一个 button-counter 组件:
在这里插入图片描述
在每次点击后,计数器会加 1:
在这里插入图片描述

这段代码展示了Vue 3中如何创建应用、定义组件、使用响应式数据、定义模板以及将应用挂载到DOM元素上的基本概念

组件的特性和优势

  那我们了解Vue组件什么了,那它的特性或者是它的优势在于哪里嘞?

Vue组件的特性

  1. 可复用性
  • 组件允许你将UI的某个部分抽象出来,并在不同的地方重复使用。
  • 这减少了代码的冗余,提高了开发效率。
  1. 模块化
  • 组件将应用拆分成多个小的、独立的模块。
  • 每个模块都有自己的逻辑、模板和样式,使得应用的结构更加清晰。
  1. 封装性
  • 组件封装了内部的状态和行为,外部只能通过属性(props)和事件(events)与组件进行交互。
  • 这有助于保护组件的内部实现,防止外部直接修改组件的状态。
  1. 响应式数据绑定
  • Vue组件支持响应式数据绑定,当数据发生变化时,视图会自动更新。
  • 这减少了手动更新DOM的需要,提高了应用的性能和可靠性。
  1. 自定义元素
  • 组件可以像HTML元素一样被使用,这使得它们非常易于集成到现有的Web应用中。

Vue组件的优势

  1. 提高开发效率
  • 通过复用组件,减少了重复代码,加快了开发速度。
  1. 易于维护
  • 组件化的结构使得代码更加清晰,易于理解和维护。
  1. 增强可扩展性
  • 组件可以通过插槽、属性和事件等方式进行扩展和自定义。
  1. 促进团队协作
  • 组件化的开发方式使得不同的开发者可以并行工作,互不干扰。

Vue代码示例
以下是一个简单的Vue组件示例,它展示了如何创建一个可复用的按钮组件,并演示了上述特性中的一些。

<!-- Button.vue -->  
<template>  <button @click="handleClick" :class="buttonClass">{{ label }}</button>  
</template>  <script>  
export default {  name: 'Button',  props: {  label: {  type: String,  required: true  },  buttonClass: {  type: String,  default: ''  },  onClick: {  type: Function,  default: null  }  },  methods: {  handleClick() {  if (this.onClick) {  this.onClick();  }  }  }  
};  
</script>  <style scoped>  
/* 这里的样式只会应用于Button组件 */  
button {  padding: 10px 20px;  font-size: 16px;  cursor: pointer;  
}  
</style>

在另一个Vue文件中使用这个组件:

<!-- App.vue -->  
<template>  <div id="app">  <Button label="点击我" buttonClass="primary-button" :onClick="handleButtonClick" />  </div>  
</template>  <script>  
import Button from './Button.vue';  export default {  name: 'App',  components: {  Button  },  methods: {  handleButtonClick() {  alert('按钮被点击了!');  }  }  
};  
</script>  <style>  
/* 全局样式 */  
.primary-button {  background-color: blue;  color: white;  border: none;  border-radius: 5px;  
}  
</style>

在这个例子中,Button组件接受三个属性:label(按钮上的文本)、buttonClass(按钮的CSS类名)和onClick(点击按钮时触发的回调函数)。组件内部使用了一个方法handleClick来处理点击事件,并调用传入的onClick回调函数(如果存在的话)。

通过这种方式,Button组件变得非常灵活和可复用,可以在不同的地方使用,并传递不同的属性和回调函数来满足不同的需求。同时,由于组件的封装性,它的内部实现被保护起来,外部只能通过属性进行交互,这有助于保持组件的独立性和稳定性。

Vue3计算属性

  Vue.js中的计算属性(computed properties)是基于它们的依赖进行缓存的响应式属性。只有当相关依赖发生改变时,它们才会重新求值。这使得计算属性非常适合用于执行复杂逻辑,同时保持高效和响应式。

  这段代码展示了如何使用Vue.js框架来创建一个简单的应用,该应用会将其数据(在这个例子中是message字符串)进行反转处理,并在页面上显示出来。这是Vue.js数据绑定和插值表达式功能的一个简单示例。
在这里插入图片描述
{{ message.split('').reverse().join('') }}:这是Vue的插值表达式。它的作用是显示message数据属性的内容,但是在显示之前,会对这个内容进行处理。
message.split(''):将message字符串分割成字符数组。
.reverse():将字符数组的元素顺序反转。
.join(''):将反转后的字符数组重新连接成一个字符串。

const app = {...}:这里定义了一个Vue应用的数据对象。data函数返回一个对象,这个对象包含了应用的数据。在这个例子中,数据对象有一个属性message,其初始值为’RUNOOB!!‘。
Vue.createApp(app).mount('#app'):这行代码创建了一个Vue应用实例,并将之前定义的app对象作为配置对象传入。然后,通过mount(’#app’)方法,将这个Vue应用挂载到页面上ID为app的div元素上

Vue3监听属性

Vue实例部分
定义了一个Vue应用程序实例app。
在data函数中,返回了一个对象,包含两个属性:kilometers和meters,初始值都为0。
使用watch选项来监听kilometers和meters属性的变化。

当kilometers变化时,如果当前活动的字段是kilometers,则将meters设置为kilometers乘以1000。

当meters变化时,如果当前活动的字段是meters,则将kilometers设置为meters除以1000。

使用Vue.createApp(app).mount(‘#app’)来创建并挂载Vue应用程序到id为app的div元素上

额外的$watch监听器
在Vue实例挂载后,使用vm.$watch方法额外监听kilometers属性的变化。
当kilometers的值变化时,这个监听器会更新id为info的p元素的innerHTML,显示修改前后的值
在这里插入图片描述

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

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

相关文章

(AtCoder Beginner Contest 375) 题解(下)

一、题解 第 E 题 3 Team Division 一眼看像背包&#xff0c;观察数据范围&#xff0c;合法的总能力值 ≤ 500 \le 500 ≤500&#xff0c;那么我们可以设计一个背包DP&#xff1a; int dp[110][510][510]; //dp[i][j][k] 表示前 i 个人&#xff0c;分给第一组的能力值是 j&…

微服务架构 --- 使用Seata处理分布式事务

目录 一.Seata 是什么? 1.Seata的核心架构&#xff1a; 2. Seata的分布式事务处理流程&#xff1a; 二.Seata的基本使用&#xff1a; 1.环境准备&#xff1a; 2.引入依赖&#xff1a; 3.加入配置来使用Seata&#xff1a; &#xff08;1&#xff09;首先在nacos上添加一…

免费版视频压缩软件:让视频处理更便捷

现在不少人已经习惯通过视频来记录生活、传播信息和进行娱乐的重要方式。但是由于设备大家现在录制的文件都会比较大&#xff0c;这时候就比较需要一些缩小视频的工具了。今天我们一起来探讨视频压缩软件免费版来为我们带来的生动世界。 1.Foxit视频压缩大师 链接直达&#x…

ESP32移植Openharmony外设篇(1)MQ-2烟雾传感器

外设篇 实验箱介绍 旗舰版实验箱由2部分组成&#xff1a;鸿蒙外设模块&#xff08;支持同时8个工作&#xff09;、鸿蒙平板。 其中&#xff0c;鸿蒙平板默认采用RK3566方案。 OpenHarmony外设模块采用底板传感器拓展板方式&#xff0c;底板默认采用ESP32方案&#xff0c;也…

青少年编程能力等级测评CPA C++一级试卷(1)

青少年编程能力等级测评CPA C一级试卷&#xff08;1&#xff09; 一、单项选择题&#xff08;共20题&#xff0c;每题3.5分&#xff0c;共70分&#xff09; CP1_1_1&#xff0e;在C中&#xff0c;下列变量名正确的是&#xff08; &#xff09;。 A&#xff0e;$123 B&#…

Redis 的安装与部署(图文)

前言 Redis 暂不支持Windows 系统&#xff0c;官网上只能下载Linux 环境的安装包。但是启用WSL2 就可以在Windows 上运行Linux 二进制文件。[要使此方法工作&#xff0c;需要运行Windows 10 2004版及更高版本或Windows 11]。本文在CentOS Linux 系统上安装最新版Redis&#xf…

【C++】unordered_set、unordered_map超详细封装过程,处理底层细节

&#x1f680;个人主页&#xff1a;小羊 &#x1f680;所属专栏&#xff1a;C 很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~ 目录 前言1、数据泛型2、迭代器2.1 重载2.2 begin、end2.3 const迭代器2.4 unordered_map中[]重载 3、特殊类型 总结 前…

如何设计开发RTSP直播播放器?

技术背景 我们在对接RTSP直播播放器相关技术诉求的时候&#xff0c;好多开发者&#xff0c;除了选用成熟的RTSP播放器外&#xff0c;还想知其然知其所以然&#xff0c;对RTSP播放器的整体开发有个基础的了解&#xff0c;方便方案之作和技术延伸。本文抛砖引玉&#xff0c;做个…

Unity 实战案例全解析 实现时间停止效果+世界变灰

画面里运动的那个小玩意这么写 using System.Collections; using System.Collections.Generic; using UnityEngine;public class Partol : MonoBehaviour {public Transform pos1;public Transform pos2;public float speed;private Transform target;void Start() {target p…

前端开发攻略---取消已经发出但是还未响应的网络请求

目录 注意&#xff1a; 1、Axios实现 2、Fetch实现 3、XHR实现 注意&#xff1a; 当请求被取消时&#xff0c;只会本地停止处理此次请求&#xff0c;服务器仍然可能已经接收到了并处理了该请求。开发时应当及时和后端进行友好沟通。 1、Axios实现 <!DOCTYPE html> &…

性能测试工具JMeter

本次使用的博客系统的url&#xff1a; http://8.137.19.140:9090/blog_edit.html 1. JMeter介绍 环境要求&#xff1a;要求java&#xff0c;jdk版本大于8&#xff1b; Apache JMeter 是 Apache 组织基于 Java 开发的压⼒测试⼯具&#xff0c;⽤于对软件做性能测试&#xff1b…

带新手用一套坦克大战搞定Java核心编程

有不少在校大学生朋友私信笔者&#xff0c;觉得现在的Java教程学的比较枯燥&#xff0c;有没有能学到基础知识同时还有做项目感觉的教程。因为笔者最早接触Java时学的是马士兵老师、韩顺平老师这样的大佬当时出的教程&#xff0c;尤其印象深刻的是二位大佬的坦克大战项目&#…

基于DSP+ARM+FPGA的电能质量分析仪的软件设计

软件设计是电能质量设备的核心内容&#xff0c;上述章节详细介绍了电能质量参数的 算法&#xff0c;并且通过仿真实验进行了验证&#xff0c;本章将结合现代电能质量监测设备需求实 现算法在实际电网中应用。根据设计的电能质量分析仪的需求分析&#xff0c;进行总体的 软件…

Java筑基之路:运算符深入(下)

&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d;&#x1f51d; &#x1f947;博主昵称&#xff1a;小菜元 &#x1f35f;博客主页…

计算机网络:数据链路层 —— 共享式以太网

文章目录 共享式以太网CSMA/CD 协议CSMA/CD 协议 的基本原理 共享式以太网的争用期共享式以太网的最小帧长共享式以太网的最大帧长共享式以太网的退避算法截断二进制指数退避算法 共享二进制以太网的信道利用率使用集线器的共享式以太网10BASE-T 共享式以太网 共享式以太网是当…

51单片机数码管循环显示0~f

原理图&#xff1a; #include <reg52.h>sbit dulaP2^6;//段选信号 sbit welaP2^7;//位选信号unsigned char num;//数码管显示的数字0~funsigned char code table[]{ 0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71};//定义数码管显…

yakit使用教程(四,信息收集)

本文仅作为学习参考使用&#xff0c;本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 前言&#xff1a;yakit下载安装教程。 一&#xff0c;基础爬虫。 在新建项目或新建临时项目后&#xff0c;点击安全工具&#xff0c;点击基础爬虫。 此工具并不是为了爬取网站上的一…

navicat下载教程(包会的)

目录 一、下载navicat安装包 步骤1---试用版本 步骤2---下载windws系统的navicat​编辑 步骤3---查看安装包 二、安装navicat 三、唤醒navicat 四、成功唤醒navicat 官网地址&#xff1a;Navicat | 下载 Navicat Premium 14 天免费 Windows、macOS 和 Linux 的试用版 …

[Linux] 创建可以免密登录的SFTP用户

本文主要包含: 创建新用户创建密钥对用于免密登录新用户将新建用户改造为SFTP用户为SFTP上传数据设置限速 1. 创建新用户 sudo useradd sftp_user sudo passwd sftp_user # 输入密码2. 创建密钥对 参考这篇文章 [Linux] 生成 PEM 密钥对实现服务器的免密登录 3. 将新建用户…

牛客习题—线性DP 【mari和shiny】C++

你好&#xff0c;欢迎阅读我的文章~ 个人主页&#xff1a;Mike 所属专栏&#xff1a;动态规划 mari和shiny mari和shiny ​ 分析: 使用动态规划的思路来解决。 思路&#xff1a; 分别统计s&#xff0c;sh&#xff0c;shy的数量即可。使用ss来统计字符s的数量&#xff0c;使…