Reactive判断的API

Reactive判断API

      • [1. isProxy](#1. isProxy)
      • [2. isReactive](#2. isReactive)
      • [3. isReadonly](#3. isReadonly)
      • [4. toRaw](#4. toRaw)
      • [5. shallowReactive](#5. shallowReactive)
      • [6. shallowReadonly](#6. shallowReadonly)

1. isProxy

复制代码
    检查对象是否是由reactive或readonly创建的proxy.
javascript 复制代码
  	const info1 = reactive({
      name:'why',
       age:18
     })
	 const info2 = readonly(reactive({
      name:'why',
       age:18
     }))
    console.log(isProxy(info1),isProxy(info2));//true true

2. isReactive

复制代码
     检查对象是否由reactive创建的响应式代理:
     如果该代理是readonly创建的,但包裹了由reactive创建的另一个代理,它也会返回true
javascript 复制代码
  	const info1 = reactive({
      name:'why',
       age:18
     })
	 const info2 = readonly(reactive({
      name:'why',
       age:18
     }))
    console.log(isReactive(info1),isReactive(info2));//true true

3. isReadonly

复制代码
      检查对象是否由readonly创建的只读代理。
javascript 复制代码
  	const info1 = readonly({
      name:'why',
       age:18
     })
	 const info2 = readonly(reactive({
      name:'why',
       age:18
     }))
    console.log(isReadonly(info1),isReadonly(info2));//true true

4. toRaw

复制代码
      返回reactive或readonly代理的原始对象(不建议保留对原始对象的持久引用。谨慎使用(转成原始对象之后是要修改原始对象不推荐))
javascript 复制代码
      const info1 = readonly({
        name:'why',
        age:18
      })
      const info2 = reactive({
        name:'why',
        age:18
      })
     
      console.log(toRaw(info1),toRaw(info2)); //{name: 'why', age: 18} {name: 'why', age: 18}

5. shallowReactive

复制代码
      创建一个响应式代理,它跟踪其自身property的响应性,但不执行嵌套对象深层响应式转换(深层还是原生对象)
      注意点:修改后视图不刷新。修改carName的时候,不能把其他响应式数据也放到里面,不然会带着一起修改视图
javascript 复制代码
		<template>
		  <div>
		   <h2>
		    {{ info.car.name }} //视图不更新
		   </h2>
		   <button @click="chagneCarName">修改carName</button>
		  </div>
		</template>
		
      const info = shallowReactive({
        name:'why',
        age:18,
        car:{
          name:'xx'
        }
      })

      const chagneCarName = () => {
        info.car.name = 'yy'
      }

6. shallowReadonly

复制代码
      创建一个proxy,使其自身的property为只读,但不执行嵌套对象的深度只读转换(深层还是可读、可写)
javascript 复制代码
      const user = shallowReadonly({
        name: 'Alice',
        address: {
          street: '123 Main St',
          city: 'Wonderland',
        }
      })
    
       const changName = () => {
        user.name = '456 Elm St'; // 视图不会更新
      }
相关推荐
写代码的皮筏艇9 分钟前
React中的'插槽'
前端·javascript
韩曙亮9 分钟前
【Web APIs】元素可视区 client 系列属性 ② ( 立即执行函数 )
前端·javascript·dom·client·web apis·立即执行函数·元素可视区
像素水藻码10 分钟前
Vue3 源码学习笔记(一):环境搭建与初识Monorepo
vue.js
羊羊小栈11 分钟前
基于「YOLO姿态识别 + AI大模型分析」的智能健身辅助系统(vue+flask+AI算法)
vue.js·人工智能·yolo·毕业设计·创业创新·大作业
秋邱12 分钟前
AR 技术创新与商业化新方向:AI+AR 融合,抢占 2025 高潜力赛道
前端·人工智能·后端·python·html·restful
一只一只妖12 分钟前
Taro+Vue3+TS+Vite 小程序开发底座搭建流程
vue.js·小程序·taro
随笔记13 分钟前
uniapp开发app使用海康威视播放监控视频流如何使用以及遇到了什么问题
vue.js·uni-app·视频编码
www_stdio13 分钟前
JavaScript 原型继承与函数调用机制详解
前端·javascript·面试
羽沢3116 分钟前
vue3 + element-plus 表单校验
前端·javascript·vue.js
前端九哥18 分钟前
如何让AI设计出Apple风格的顶级UI?
前端·人工智能