当前位置: 首页 > news >正文

前端面试十二之vue3基础

一、ref和reactive

在 Vue 3 中,refreactive 是两种主要的响应式数据创建方式,它们各有特点和适用场景。

1.ref

ref 主要用于创建单个值的响应式引用,通常用于基本类型数据,如数字、字符串等。使用 ref 创建的引用对象可以通过 .value 属性访问内部的值。例如:

import { ref } from 'vue';const count = ref(0); // 创建一个初始值为 0 的响应式引用
console.log(count.value); // 输出 0
count.value++; // 修改引用对象的值
console.log(count.value); // 输出 1

ref 创建的数据是被追踪的,但是只有在访问 .value 属性时才会触发依赖追踪。

2.reactive

reactive 主要用于创建包含多个属性的响应式对象,通常用于创建对象。使用 reactive 创建的响应式对象直接访问属性,并进行修改,就像操作普通 JavaScript 对象一样。例如:

import { reactive } from 'vue';const person = reactive({name: 'John',age: 30
});console.log(person.name); // 输出 'John'
console.log(person.age); // 输出 30person.name = 'Jane'; // 修改对象的 name 属性的值为 'Jane'
person.age = 25; // 修改对象的 age 属性的值为 25console.log(person); // 输出 { name: 'Jane', age: 25 }

reactive 创建的对象及其内部属性都是被完全追踪的,当任何属性被修改时,所有依赖于这些属性的视图都会自动更新。

3.应用场景

  • 如果你只需要管理单个值的响应性,或者需要在模板中使用响应式数据,那么 ref 是一个不错的选择。

  • 如果你需要创建包含多个属性的对象,并且希望这些属性都是响应式的,那么 reactive 更适合用于创建对象。

4.总结

refreactive 在 Vue 3 中是两种不同的响应式数据创建方式,它们各有特点和适用场景。根据具体需求选择合适的方式来管理组件中的数据,将会让你的代码更加清晰和易于维护。

二、属性绑定与事件绑定  

在 Vue 3 中,属性绑定和事件绑定是将数据和事件处理逻辑与模板连接起来的重要方式。它们使得在模板中可以直接使用组件的属性和监听事件,从而实现动态的用户界面。

属性绑定(Property Binding)

属性绑定允许你将组件的属性动态地绑定到模板中的元素或组件上。这可以通过使用 v-bind 指令(通常缩写为 :)来实现。

事件绑定(Event Binding)

事件绑定允许你在模板中监听 DOM 事件或组件事件,并将它们连接到组件的方法上。这可以通过使用 v-on 指令(通常缩写为 @)来实现。

<template><div><!-- 文本内容的属性绑定 --><p :text="message"></p><!-- 图片 src 属性的绑定 --><img :src="imageUrl" alt="Description"><!-- 数据更新按钮,点击时修改 message --><button @click="updateMessage">Change Message</button></div>
</template><script setup>
import { ref } from 'vue';// 定义响应式数据
const message = ref('Hello Vue 3');
const imageUrl = ref('https://example.com/image.jpg');// 更新 message 的函数
function updateMessage() {message.value = 'Updated message in Vue 3!';
}
</script>

三、表单绑定 

在 Vue 3 中,表单绑定是一个常见的需求,用于将表单元素(如 <input><select><textarea> 等)与组件的数据进行双向绑定。Vue 3 提供了灵活的表单绑定方法,包括 v-model 指令和 v-model 的使用方式。 

1.v-model 指令

v-model 是 Vue 3 中用于实现双向数据绑定的特殊指令。它自动将表单元素的值与组件的数据属性进行同步。

<template><div><!-- 文本输入 --><input v-model="message" placeholder="Type something..." /><!-- 复选框 --><input type="checkbox" v-model="checked" /><!-- 单选按钮 --><input type="radio" value="one" v-model="picked" /><input type="radio" value="two" v-model="picked" /><!-- 选择框 --><select v-model="selected"><option disabled value="">Please select one</option><option>A</option><option>B</option><option>C</option></select><!-- 输出 --><p>Message: {{ message }}</p><p>Checked: {{ checked }}</p><p>Picked: {{ picked }}</p><p>Selected: {{ selected }}</p></div>
</template><script setup>
import { ref } from 'vue';const message = ref('');
const checked = ref(false);
const picked = ref('one');
const selected = ref('');
</script>

2.修饰符

Vue 3 为 v-model 提供了一些修饰符,以增强其功能:

  • .lazy:在默认情况下,v-model 在每次 input 事件触发时更新数据。使用 .lazy 修饰符可以改为在 change 事件触发时更新。

  • .number:自动将用户的输入值转换为数值类型。

  • .trim:自动过滤用户输入的首尾空格。

    <template><div><!-- 默认情况下,每次 input 事件触发时更新 --><input v-model="message" placeholder="Type something..." /><!-- 使用 .lazy 修饰符,在 change 事件触发时更新 --><input v-model.lazy="messageLazy" placeholder="Type something..." /><!-- 使用 .number 修饰符,自动转换为数值类型 --><input v-model.number="age" type="number" /><!-- 使用 .trim 修饰符,自动过滤首尾空格 --><input v-model.trim="messageTrim" placeholder="Type something..." /></div>
    </template><script setup>
    import { ref } from 'vue';const message = ref('');
    const messageLazy = ref('');
    const age = ref(0);
    const messageTrim = ref('');
    </script>

    四、计算属性

在 Vue 3 中,计算属性(Computed Properties)是一种声明式的方法,用于声明性地描述一个值是如何根据组件的响应式数据计算得来的。计算属性是基于它们的响应式依赖进行缓存的,只有当相关响应式数据发生变化时,计算属性才会重新计算。 

<template><div><p>Message: {{ message }}</p><p>Reversed Message: {{ reversedMessage }}</p></div>
</template><script setup>
import { ref, computed } from 'vue';const message = ref('Hello Vue 3');// 定义计算属性
const reversedMessage = computed(() => {return message.value.split('').reverse().join('');
});
</script>

计算属性的选项

computed 函数可以接受一个选项对象,其中包含 getset 函数:

  • get 函数:用于计算属性的值。

  • set 函数(可选):用于设置属性的值,这使得计算属性也可以是可写的。

    <script setup>
    import { ref, computed } from 'vue';const message = ref('Hello Vue 3');// 定义可写的计算属性
    const reversedMessage = computed({get: () => {return message.value.split('').reverse().join('');},set: (newValue) => {message.value = newValue.split('').reverse().join('');}
    });
    </script>

http://www.lryc.cn/news/587464.html

相关文章:

  • 从代码学习深度强化学习 - DDPG PyTorch版
  • CCPD 车牌数据集提取标注,并转为标准 YOLO 格式
  • MySQL 分表功能应用场景实现全方位详解与示例
  • JavaSE-多态
  • 010_学习资源与社区支持
  • Linux713 SAMBA;磁盘管理:手动挂载,开机自动挂载,自动挂载
  • 输入npm install后发生了什么
  • C++高频知识点(十)
  • Excalidraw:一款颠覆传统思维的免费开源绘图工具
  • 什么是RAG(Retrieval-Augmented Generation)?一文读懂检索增强生成
  • Vue3 实现文件上传功能
  • 【操作系统】strace 跟踪系统调用(一)
  • 网络编程 JAVA
  • 2025年渗透测试面试题总结-2025年HW(护网面试) 45(题目+回答)
  • 学习开发之无参与有参
  • 前四天综合总结
  • Cursor的使用
  • ARC 03 从Github Action job 到 runner pod
  • 暑期自学嵌入式——Day01(C语言阶段)
  • BERT系列模型
  • Spring AI 项目实战(十六):Spring Boot + AI + 通义万相图像生成工具全栈项目实战(附完整源码)
  • 闲庭信步使用图像验证平台加速FPGA的开发:第十三课——图像浮雕效果的FPGA实现
  • 【Mysql作业】
  • 16.使用ResNet网络进行Fashion-Mnist分类
  • [GWCTF 2019]我有一个数据库
  • 在 Ubuntu 下安装 MySQL 数据库
  • 谷歌推出Vertex AI Memory Bank:为AI智能体带来持久记忆,支持连续对话
  • 【echarts踩坑记录】为什么第二个Y轴最大值不整洁
  • 华为HarmonyOS 5.0深度解析:跨设备算力池技术白皮书(2025全场景智慧中枢)
  • JavaScript加强篇——第八章 高效渲染与正则表达式