亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue六大基本類型中的原始值響應(yīng)式

 更新時間:2023年01月04日 08:40:09   作者:知奕奕  
原始值指的是 Boolean、Number、BigInt、String、Symbol、undefined、null 等類型的值,在 JavaScript 中,原始值是按值傳遞的,引用類型是按引用傳遞的,這意味著,如果一個函數(shù)接收了一個原始值作為參數(shù),那么形參和實參之間是沒有引用關(guān)系的,它們是完全獨立的兩個值

所謂原始值即針對六大基本類型的值的響應(yīng)式

ref

由于 proxy 無法阻止原始值的修改,故此方法在這里不管用

我們可以創(chuàng)建一個包裹對象把原始值包起來;

然后在使用 reactive 將該包裹對象變成響應(yīng)式的即可

__v_isRef 屬性是用來判斷是否為 ref 包裹對象的判據(jù)

function ref(val) {
  // 包裹對象
  const wrapper = {
    value: val,
  };
  // 是否為ref的判據(jù)
  Object.defineProperty(wrapper, "__v_isRef", {
    value: true,
  });
  // 返回響應(yīng)式數(shù)據(jù)
  return reactive(wrapper);
}

響應(yīng)丟失

響應(yīng)丟失問題:使用 reactive 創(chuàng)建響應(yīng)式對象后,使用多參的形式 return,則實際上返回的是普通對象而非響應(yīng)式對象!

export default {
  setup() {
    const obj = reactive({ a: 1, b: 2 });
    return {
      ...obj,
    };
  },
};

響應(yīng)關(guān)系建立

obj 為原響應(yīng)對象

newobj 內(nèi)擁有與 obj 同名的所有屬性值,且均一一編寫訪問器屬性 value

value 執(zhí)行后返回原響應(yīng)對象中的值

這樣一來,修改 obj 屬性后,便會自動觸發(fā)副作用函數(shù)執(zhí)行!

const obj = reactive({ a: 1, b: 2 });
const newobj = {
  a: {
    get value() {
      return obj.a;
    },
  },
  b: {
    get value() {
      return obj.b;
    },
  },
};
console.log(newobj.a.value);

toRef 函數(shù)的實現(xiàn)

使用包裹 wrapper,內(nèi)部加上 getter、setter 方法實現(xiàn)響應(yīng)式

function toRef(obj, key) {
  const wrapper = {
    get value() {
      return obj[key];
    },
    set value(val) {
      obj[key] = val;
    },
  };
  Object.defineProperty(wrapper, "__v_isRef", {
    value: true,
  });
  return wrapper;
}

自動脫 ref

使用 proxy 代理

判斷如果存在屬性 __v_isRef ,表示其為 ref,則返回該 ref 的值;

如果只是普通對象,那原樣返回即可

function proxyRefs(target) {
  return new Proxy(target, {
    get(target, key, receiver) {
      const value = Reflect.get(target, key, receiver);
      return value.__v_isRef ? value.value : value;
    },
  });
}

reactive 就是一個自動脫 ref 的例子,使用他的時候無需額外調(diào)用 value 即可獲取值

到此這篇關(guān)于Vue六大基本類型中的原始值響應(yīng)式的文章就介紹到這了,更多相關(guān)Vue原始值響應(yīng)式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue滑塊驗證碼組件anji-captcha的使用案例詳解

    Vue滑塊驗證碼組件anji-captcha的使用案例詳解

    滑塊驗證是一種常見的人機(jī)識別方法,這篇文章主要介紹了Vue滑塊驗證碼組件anji-captcha的使用,本文通過實例代碼圖文相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • vue 實現(xiàn)特定條件下綁定事件

    vue 實現(xiàn)特定條件下綁定事件

    今天小編就為大家分享一篇vue 實現(xiàn)特定條件下綁定事件,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue3遞歸組件封裝的全過程記錄

    vue3遞歸組件封裝的全過程記錄

    組件是可以在自己的模板中調(diào)用自身的,不過他們只能通過name選項來做這件事,下面這篇文章主要給大家介紹了關(guān)于vue3遞歸組件封裝的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • vue攔截器如何增加token參數(shù)

    vue攔截器如何增加token參數(shù)

    這篇文章主要介紹了vue攔截器如何增加token參數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • ant-design-vue 時間選擇器賦值默認(rèn)時間的操作

    ant-design-vue 時間選擇器賦值默認(rèn)時間的操作

    這篇文章主要介紹了ant-design-vue 時間選擇器賦值默認(rèn)時間的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨過來看看吧
    2020-10-10
  • vue.js開發(fā)實現(xiàn)全局調(diào)用的MessageBox組件實例代碼

    vue.js開發(fā)實現(xiàn)全局調(diào)用的MessageBox組件實例代碼

    最近學(xué)習(xí)了Vue.js,感覺組件這個地方知識點挺多的,而且很重要,所以決定記錄下,下面這篇文章主要給大家介紹了關(guān)于利用vue.js開發(fā)實現(xiàn)全局調(diào)用的MessageBox組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-11-11
  • vue2.x中$attrs的使用方法教程

    vue2.x中$attrs的使用方法教程

    正常情況下Vue推薦用props向子組件參數(shù),但是在特定場景下,使用$attrs會更方便,下面這篇文章主要給大家介紹了關(guān)于vue2.x中$attrs使用的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue router返回到指定的路由的場景分析

    vue router返回到指定的路由的場景分析

    這篇文章主要介紹了vue router返回到指定的路由的場景分析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • 解決vue頁面渲染但dom沒渲染的操作

    解決vue頁面渲染但dom沒渲染的操作

    這篇文章主要介紹了解決vue頁面渲染但dom沒渲染的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue?this.$refs.xxx獲取dom注意事項?v-if?v-for渲染的dom不能直接使用

    vue?this.$refs.xxx獲取dom注意事項?v-if?v-for渲染的dom不能直接使用

    這篇文章主要介紹了vue?this.$refs.xxx獲取dom注意事項?v-if?v-for渲染的dom不能直接使用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評論