vue3 ref的用法及click事件的说明

1、ref可以定义一个简单的属性,也可以是一个复杂的列表、数组等等。

2、为什么要使用 ref?简单的let个变量不行吗?const个变量不行吗?

      其实这个跟vue的响应式的系统有关,官方的说明如下:

3、为 ref() 标注类型

一般我们直接赋string的时候,会自动推导出是string,但是我们在开发的过程中会经常遇到,可能要赋个日期型的,比如 dayjs,然后我们传到服务器的时候,是一个string类型,这样我们就要指导类型,让系统知道我们的编写是正确的。

4、深层响应性

5、@click

绑定到一个方法/函数。 这个 @click 语法是 v-on:click 的简写。也就是可以直接@click="func名",也可以v-on:click="func名"。

6、简单的官方事例:

https://cn.vuejs.org/examples/#handling-input

<!--
这个示例展示了如何通过 v-on 指令处理用户输入。
-->

<script setup>
import { ref } from 'vue'

const message = ref('Hello World!')

function reverseMessage() {
  // 通过其 .value 属性
  // 访问/修改一个 ref 的值。
  message.value = message.value.split('').reverse().join('')
}

function notify() {
  alert('navigation was prevented.')
}
</script>

<template>
  <!--
    注意我们不需要在模板中写 .value,
    因为在模板中 ref 会自动“解包”。
  -->
  <h1>{{ message }}</h1>

  <!--
    绑定到一个方法/函数。
    这个 @click 语法是 v-on:click 的简写。
  -->
  <button @click="reverseMessage">Reverse Message</button>

  <!-- 也可以写成一个内联表达式语句 -->
  <button @click="message += '!'">Append "!"</button>

  <!--
    Vue 也为一些像 e.preventDefault() 和 e.stopPropagation()
    这样的常见任务提供了修饰符。
  -->
  <a href="https://vuejs.org" @click.prevent="notify">
    A link with e.preventDefault()
  </a>
</template>

<style>
button, a {
  display: block;
  margin-bottom: 1em;
}
</style>

7、运行结果:

8、总结

ref可以定义类型,也可以不指定通过类型推导出来,ref是响应式的,也就是说你修改了,会自动去更新UI,而普通的变量不会,ref在template中引用的时候,不需要.vaue,会自动解包。

在script中引用的时候,一定要加上.value或者unref(变量),否则是要报错的。

### 在 Vue3 中使用 `ref` 获取 DOM 元素的高度 为了在 Vue3 中获取 DOM 元素的高度,可以通过组合式 API 的方式来操作。具体来说,在模板中定义带有 `ref` 属性的 HTML 元素,并在 `<script setup>` 或者选项式的 `<script>` 部分初始化对应的响应式引用变量。 当组件挂载完成后,即可以在生命周期钩子函数 `onMounted` 内部访问到这个元素并读取其高度属性: ```html <template> <div ref="mains" class="search"></div> </template> <script setup lang="ts"> import { ref, onMounted } from &#39;vue&#39; const mains = ref(null) onMounted(() => { if (mains.value) { const height = mains.value.clientHeight console.log(&#39;Element Height:&#39;, height) } }) </script> <style scoped lang="less"> .search { width: 100px; height: 100px; margin: 0 auto; background-color: greenyellow; } </style> ``` 上述代码展示了如何声明一个名为 `mains` 的响应式引用对象用于存储目标 DOM 节点[^1]。一旦页面加载完毕并且组件成功渲染至浏览器文档流之后,就会触发 `onMounted()` 生命周期回调,在这里可以直接通过 `.value` 访问实际的 DOM 对象进而调用它的原生 JavaScript 方法或属性比如 `clientHeight` 来取得当前元素可视区域内的真实尺寸[^2]。 值得注意的是,由于 TypeScript 类型推断机制的存在,最好为 `ref()` 明确指定预期的数据类型以避免潜在错误;另外还需注意检查 `mains.value !== null && mains.value !== undefined` ,防止未及时更新导致的操作失败情况发生[^3]。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值