IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3之toRef、toRefs、toRaw -> 正文阅读

[JavaScript知识库]vue3之toRef、toRefs、toRaw

vue3之toRef

  • toRef是将对象中的某个值转化为响应式数据 toRef(obj,key)

toRef定义原始数据非响应式数据

  • toRef 如果原始对象是非响应式的就不会更新视图 数据是会变的
<template>
  <div>
    <button @click="change">change</button>
    <div>{{ obj }}</div>
  </div>
</template>

<script setup lang="ts">
import { toRef, reactive } from 'vue'

const obj = {
  num: 1,
  count: 2,
}
let state = toRef(obj, 'num')
// toRef 如果原始对象是非响应式的就不会更新视图 数据是会变的
// toRef 如果原始对象是响应式时,原始数据,和copy的数据 都会产生影响,视图也发生变化
const change = () => {
  state.value = 3
  obj.count = 3
  console.log('原始obj', obj)
  console.log('引用state', state)
}
</script>

  • 原始数据非响应式数据 效果
    在这里插入图片描述

toRef定义原始数据为响应式数据

  • toRef 如果原始对象是响应式时,原始数据,和copy的数据 都会产生影响,视图也发生变化
<template>
  <div>
    <button @click="change">change</button>
    <div>{{ obj }}</div>
  </div>
</template>

<script setup lang="ts">
import { toRef, reactive } from 'vue'

const obj = reactive({
  num: 1,
})
let state = toRef(obj, 'num')
// toRef 作用:就是对原始数据,和copy的数据 都会产生影响 若是使用reactive定义的复杂数据,也是会联动视图
const change = () => {
  state.value = 3
  console.log('原始obj', obj)
  console.log('引用state', state)
}
</script>
  • 效果:
    在这里插入图片描述

toRefs 可批量创建响应式数据

  • 也就是对对象解构时,解构出来的值为非响应式数据,但使用 toRefs 定义后 这些被解构出来的值 为响应式数据
<template>
  <div>
    <button @click="change">change</button>
    <div>{{ obj }}</div>
  </div>
</template>

<script setup lang="ts">
import { toRefs, reactive } from 'vue'

const obj = reactive({
  num: 1,
  count: 2,
})
let { num, count } = obj // 直接结构出来的数据,是非响应式的数据
console.log('num', num, 'count', count)
let { num: num1, count: count1 } = toRefs(obj) // 直接结构出来的数据,是非响应式的数据,通过toRefs定义为响应式数据
console.log('num1', num1, 'count1', count1)
const change = () => {
  num = 10
  count1.value = 100
  console.log('事件num', num)
}
</script>
  • 效果
    在这里插入图片描述

toRaw

  • 将响应式对象转化为普通对象
<template>
  <div>
    <button @click="change">change</button>
    <div>{{ obj }}</div>
  </div>
</template>

<script setup lang="ts">
import { toRaw, reactive } from 'vue'

const obj = reactive({
  num: 1,
  count: 2,
})
let newObj = toRaw(obj)
console.log('newObj', newObj)
const change = () => {
  newObj.count = 33
  console.log('newObj2', newObj)
}
</script>
  • 效果
    在这里插入图片描述
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-06 12:53:24  更:2022-03-06 12:54:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:03:58-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码