vueuse的unrefElement用法

在学习vueuse模块的unrefElement用法前,先来复习下ref属性在普通html标签和自定义组件标签上的用法。

看下面的例子:

<script setup>
import JuanButton from '@/components/button'
import { onMounted, ref } from 'vue'
const btn = ref()
const span = ref()
onMounted(() => {
  console.log(btn.value)

  console.log(span.value)
})
</script>
<template>
  <div class="m-8">
    <div>
      <span ref="span" class="mr-2 inline-block border border-amber-500">我是一个span</span>
      <JuanButton ref="btn" type="primary">Hello</JuanButton>
    </div>
  </div>
</template>

在这里插入图片描述

实验发现,ref作用在普通html元素上可以通过.value访问到dom元素;而对于自定义组件,则是获取组件对象:

在这里插入图片描述

要访问组件内部的dom元素,可以访问btn.value.$el

总结下来要通过ref来访问html标签对应的元素,有两种方式:

  1. html原生dom元素

    const span = ref()
    onMounted(() => {
      console.log(span.value)
    })
    
  2. 自定义组件对应的dom

    const btn = ref()
    onMounted(() => {
      console.log(btn.value.$el)
    })
    

vueuse模块的unrefElement方法提供了统一的操作方式:

<script setup>
...
import { unrefElement } from '@vueuse/core'
const btn = ref()
const span = ref()
onMounted(() => {
  console.log(unrefElement(btn))

  console.log(unrefElement(span))
})
</script>

在这里插入图片描述

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Vue项目中使用JWT(JSON Web Token),你可以按照以下步骤进行操作: 1. 安装`vueuse`库:运行以下命令安装`vueuse`库。 ``` npm install vueuse ``` 2. 创建一个`jwt.js`文件,用于处理JWT的逻辑。在该文件中,你可以编写一些方法来处理JWT的生成、解码和验证等操作。以下是一个示例: ```javascript import { ref } from 'vue'; import { useLocalStorage } from 'vueuse'; export function useJwt() { // 获取存储在本地的token const token = useLocalStorage('jwt_token', null); // 生成token function generateToken(payload) { // 编写生成token的逻辑 // 返回生成的token字符串 } // 解码token function decodeToken() { // 编写解码token的逻辑 // 返回解码后的token数据 } // 验证token function validateToken() { // 编写验证token的逻辑 // 返回token是否有效的布尔值 } return { token, generateToken, decodeToken, validateToken, }; } ``` 3. 在你的Vue组件中使用`useJwt`函数。首先,导入`useJwt`函数,然后在组件中调用该函数并使用返回的对象。 ```vue <template> <div> <button @click="generateToken">生成Token</button> <button @click="decodeToken">解码Token</button> <button @click="validateToken">验证Token</button> </div> </template> <script> import { useJwt } from './jwt.js'; export default { setup() { const { generateToken, decodeToken, validateToken } = useJwt(); return { generateToken, decodeToken, validateToken, }; }, }; </script> ``` 在以上示例中,你可以在Vue组件的`setup`函数中调用`useJwt`函数,并将返回的方法绑定到组件的属性上。然后,你可以在模板中使用这些方法来生成、解码和验证JWT。 请注意,这只是一个简单的示例,你需要根据你的实际需求来编写更完整的JWT逻辑。此外,你还需要自行实现生成、解码和验证JWT的具体逻辑,可以使用现有的JWT库(如`jsonwebtoken`)来简化开发过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java小卷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值