• 【Vue】ref,reactive 响应式引用的用法和原理(1)


    问题清单:
    这两个新的语法是解决什么样问题的?
    响应式的引用的原理是什么?
    响应式的引用有一个什么样的特性?

    在之前的笔记中我们学习了 composition API 里面 setup 这个函数的使用。‍‍

    现在我们继续 学习 composition API 里面的两个新的语法知识点,一个叫做reactive,一个叫做 ref。‍‍

    我们来看一下这两个新的语法是解决什么样问题的?

    代码示例:

    代码解读:
    我们来关注两个东西,一个叫做ref,‍‍一个叫做reactive,
    我们定义一个 let 变量,‍‍name等于dell,

    然后我再写一个延时器,setTimeout 两秒,‍‍
    然后我让 name 等于 lee,我把name导出出去,然后页面上我来使用name,‍‍或者说模板里面我来使用name:

    setup一开始等于dell,所以模版里肯定显示的是dell,

    两秒之后 name改成lee,是不是它就会变成lee,我们可以到页面上刷新一下,看一下效果:

    dell 两秒之后并没有改成 lee,

    所以现在我的数据是分享式的一个数据,‍‍你也可以看到其实它就是一个普通的变量,这个变量它肯定不是一个响应式的变量,所以它变了‍‍模板也不会改变,只会维持它一开始导出的 dell 这样的一个值。‍‍

    那么在composition API里面,实际上我们可以通过两个语法把这种‍‍普通的变量改成一个响应式的变量,或者我们叫做响应式的引用。

    响应式的引用的原理是什么?
    通过‍‍ proxy 对数据进行封装,当数据变化时‍‍触发模板等内容的更新。‍‍

    我们可以举个例子先使用一下它,再来讲它的原理。
    这里其实很简单,dell其实是一个普通的基础类型的数据,现在我用 ref 对‍‍ dell 这样的一个基础性数据做一个封装。

    ref 处理‍‍基础类型的数据,
    基础类型的数据 调用 ref 之后,它就会通过proxy,然后‍‍把 dell变成proxy 括号name或者说value‍‍ dell这样的响应式引用:

    它的底层其实就是对 dell 做了一个proxy的封装,
    然后因为proxy也就是‍‍这种双向绑定要用到的这种proxy的语法,

    在js的原生里面,它支持传入对象的这种东西,‍‍所以 dell 是个基础类型,
    我通过 ref 去处理它的时候,底层必须把它变成一个像 value dell 这样的对象,‍‍

    所以 dell 就做了这样的一个转化 通过ref,
    转化完了之后,它就变成了一个‍‍响应式的引用,响应式的引用有一个什么样的特性?

    就是这种引用当你去改变它的值的时候,‍‍页面是可以跟着它去做变化的。‍‍
    此时代码示例:

    我们看因为 name 你对 dell 做转化之后,‍‍
    它变成了一个对象,
    {value:"dell"}这样的一个东西,‍‍所以你现在两秒钟之后想去改变 name的时候,你就不能直接去改变name,

    必须得调name点value‍‍来去改变它的值才可以。‍‍
    然后你再把name给返回出去,这里其实我们应该用 name点value:

    保存一下,我们回到页面上刷新,大家会发现这个时候你点开控制台 说什么:

    ta说‍‍ Uncaught:ref is not defined,
    ta会说 ref这样的一个方法找不到,‍‍
    其实 ref 应该怎么去找?

    它从 Vue 里面去引入就行了,它是 Vue 提供给我们的一个语法,‍‍或者说一个composition API的语法,
    我们到这里刷‍‍新,页面上也不报错,也不展示内容,‍‍

    哎呀,不是说name的值都会存在value里面转化成这样的一个对象?

    所以 dell 应该在‍‍name点value里面。
    Vue 在做模板处理的时候,它会做一个转化。‍‍

    也就是说当我在这写name的时候,ta如果知道name是一个‍‍ ref 返回的这样的一个响应式的引用的话,
    它会自动的‍‍帮我们在底层调用name点value,所以在这里你就没必要自己再去写name点value了,直接写name就可以了:

    保存一下我们的页面上刷新一下dell ,两秒钟之后你会发现它变成 lee 了‍‍:

    普通的这种 js 基础类型的数据,通过 ref 一包装就变成了响应式的引用,‍‍可以实现一个响应式的效果了。‍‍

    一定要记得 ref 处理的是基础类型的数据,‍‍像字符串、数字通过它来处理是比较合适的基础类型。‍‍
    像这种数组和对象形式的东西,我就不建议大家使用 ref来处理,ref 也不方便去处理。‍‍‍‍

    ref 的特点就是见到这种基础性的数据,因为本身 proxy 它没法‍‍代理这种基础性的数据,比如说你直接代理这个 dell是不行的,
    就是 ref 底层做的事情,‍‍会先把这种基础性的数据转化成一个value 冒号这样的对象,‍‍

    然后再去通过proxy做转化,所以其实 ref 只适合于处理基础类型的数据,你再传一个对象进去,‍‍value 然后后面在它等于这个对象其实意义也不大。‍‍

    接着我们说除了这么去写我们的代码之外,我们还可以再换一个写法去写:
    const reactive 等于6,

    然后我们用reactive去写这样的代码,reactive处理‍‍非基础类型的数据,
    代码示例:

    需求是什么:

    两秒钟去改变nameObj‍‍里面 name 的值,然后把对象返回出去,我们到页面上刷新,看一下有没有这样的变化:

    数一数一二两秒是没有任何变化的,‍‍其实这种普通的对象本身它确实也就没有这种响应式的特性,但如果我们想让它具备响应式,‍‍
    在 Vue 里面,ta会提供给我们一个新的语法特性叫做reactive,它是专门处理这种‍‍非基础类型数据的,比如说对象或者数组,我们先来看一看对象,

    这里面我们这么去写,reactive,然后把这个对象变成一个响应式的引用。‍‍

    也是通过proxy‍‍把这个name dell 变成一个proxy 这样响应式的引用。‍‍

    这样的一个响应式引用,我们直接可以去改它里面的点name,

    你看上面‍‍如果它是这样的一个形式,我可以直接改它的value:

    下面也是这样的一个形式,我想改变它的直接改name就行了。‍‍当然我return也return一个nameObj。

    上面我想用它里面的 name 也是这么写:

    只要加一个reactive给一个对象再去调用对象里面的东西,就具备响应式的特性了,我们看一下是不是这样的,‍‍刷新:

    所以我们能够看到,当你去做这样的一个非基础类型数据的响应式的处理的时候,就可以用reactive来做处理。‍‍

  • 相关阅读:
    糖葫芦低通滤波器的设计
    Win10自带输入法怎么删除-Win10卸载微软输入法的方法
    es索引同步
    Kafka收发消息核心参数详解
    【C++】左值和右值
    Python文件及目录操作(基本文件操作篇)
    VS Code调试使用标准输入功能的go程序的问题
    SVN服务端客户端安装配置
    springboot银行客户管理系统毕业设计源码250903
    【深入理解设计模式】外观设计模式
  • 原文地址:https://blog.csdn.net/YJG7D314/article/details/127604451