vue3 ref、reactive、toRef、toRefs 使用

ref、reactive、toRef、toRefs 使用

 

触发页面更新(ref,reactive)

ref : 复制,修改响应式数据不会影响原始数据 ,一次只能定义一个ref响应式数据

let age = ref(20);//响应式数据,ui更新

 

响应式原理:ref 则是用把数据给包装成 ref 对象, .value 的方式去访问其数据,在 setup 中吗,在模板中不需要, 因为会自动添加.value。vue 强烈建议 ref 用来处理 非指针类型的数据类型, string number 等, 通过给 value 属性添加 getter/setter 来实现对数据的劫持

 

reactIve:用来处理对象,数组,等指针类型的数据

响应式原理:reactive 是利用 proxy 来实现

  • ref可用于任何类型的数据创建响应式,reactive(obj|array)只用于创建引用类型数据的响应式。

<template>
    <div>
        <div @click="name='李四'">{{name}}</div>
        <div @click="age=21">{{age}}</div>
    </div>
</template>
<script>
import { reactive, ref, toRefs } from 'vue';
export default {
    name:'Page2',
    setup(){
        const state = reactive({
            name:"张三",
            age:20
        })
        return{
            ...toRefs(state)//解构赋值后数据就会失去响应式,需要用toRefs让对象拥有ref响应式属性,UI才会视图更新
        }
    }
}

注意:还有一种情况是,如果直接给响应的引用数据赋值,数据会变化但是ui不会更新

<script setup>
import {toRef,toRefs,reactive} from 'vue'

let dataObj = reactive({
  trade_url:'',
  twitter_url:'',
  telegram_url:'',
  msn_url:''
})
const change = ()=>{
    let obj = { 
        trade_url:'1',
        twitter_url:'2',
        telegram_url:'3',
        msn_url:'4'
    }
    dataObj = obj;

    console.log(dataObj); //数据都变化了,视图不会更新,没有检测到数据的变化

  
   
   // Object.assign(dataObj,obj)  
    //这样会检测到数据的变化更新ui,assign方法类似于对对象的每个属性赋值,此时vue会检测到变化,等效于下方的操作。
    // dataObj.trade_url = obj.trade_url;
    // dataObj.twitter_url = obj.twitter_url;
    // dataObj.telegram_url = obj.telegram_url;
    // dataObj.msn_url = obj.msn_url;

  //如果是数组的话直接=也是不会更新。可使用concat,或者其他数组方法

 

不会触发页面更新(toRef,toRefs)

toRef:

使用toRef将某个对象中的属性变成响应式数据,修改响应式数据是会影响到原始数据的。但是需要注意,如果修改通过toRef创建的响应式数据,并不会触发UI界面的更新。 所以,toRef的本质是引用,与原始数据有关联

import {toRef} from 'vue';
export default {
  name:'App'
  setup(){
    let obj = {name : 'alice', age : 12};
    let newObj= toRef(obj, 'name');
    function change(){
      newObj.value = 'Tom';
      console.log(obj,newObj)
    }
    return {newObj,change}
  }
}

 

上述代码,当change执行的时候,响应式数据发生改变,原始数据obj也会改变,但是UI界面不会更新

上面两个介绍了,ref 和 reactive 可以改变页面。接下来这两个则不能去改变页面,但是数据还是会遵循响应式。

小结:

ref和toRef的区别、特点: (1). ref本质是拷贝,修改响应式数据不会影响原始数据;toRef的本质是引用关系,修改响应式数据会影响原始数据 (2). ref数据发生改变,界面会自动更新;toRef当数据发生改变是,界面不会自动更新 (3). toRef传参与ref不同;toRef接收两个参数,第一个参数是哪个对象,第二个参数是对象的哪个属性

(4).toRef 用于创建对象指定的属性响应式,换句话说就是只能控制一个对象中的一个属性。

(5).toRefs 用于创建对象响应式。

(6).他们对响应式的处理你可以理解为: toRef 类似 ref, toRefs 类似 reactive

类型是否触发页面改变是否可以结构
ref
reactive
toRef
toRefs

 

 

 

posted @ 2021-06-04 16:15  小不点灬  阅读(2645)  评论(2编辑  收藏  举报