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

vue如何修改data中的obj數(shù)據(jù)的屬性

 更新時(shí)間:2022年08月03日 11:16:32   作者:乾復(fù)道  
這篇文章主要介紹了vue如何修改data中的obj數(shù)據(jù)的屬性,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

修改data中的obj數(shù)據(jù)的屬性

//方法一
var obj = this.obj;
obj.name = 'long';
this.obj = obj;
//方法二
Vue.set(this.obj, "password", "num");
//part1,要修改的obj對(duì)象;
//part2,要添加或者修改的屬性;
//part3,修改值;

修改data以實(shí)現(xiàn)數(shù)據(jù)響應(yīng)式

Vue為了實(shí)現(xiàn)在數(shù)據(jù)變化時(shí)對(duì)頁面重新渲染。所以在初始化時(shí)對(duì)傳進(jìn)來來的數(shù)據(jù)對(duì)象進(jìn)行監(jiān)聽。

怎么保證你的變化我Vue能監(jiān)聽到?

監(jiān)聽的操作就是:對(duì)數(shù)據(jù)對(duì)象的每一個(gè)數(shù)據(jù),內(nèi)部?jī)?nèi)部聲明一個(gè)變量,存儲(chǔ)這個(gè)傳進(jìn)來的初始值,然后開始了代理模式。后續(xù)對(duì)這個(gè)數(shù)據(jù)的讀取和修改,實(shí)際都是對(duì)這個(gè)內(nèi)部變量的getter和setter。由此所有的修改都會(huì)經(jīng)過setter,那么只需要setter的時(shí)候觸發(fā)監(jiān)聽函數(shù),渲染頁面即可。

當(dāng)你把一個(gè)普通的 JavaScript 對(duì)象傳入 Vue 實(shí)例作為 data 選項(xiàng),Vue 將遍歷此對(duì)象所有的 property,并使用 Object.defineProperty 把這些 property 全部轉(zhuǎn)為 getter/setter。

每個(gè)組件實(shí)例都對(duì)應(yīng)一個(gè) watcher 實(shí)例,它會(huì)在組件渲染的過程中把“接觸”過的數(shù)據(jù) property 記錄為依賴。之后當(dāng)依賴項(xiàng)的 setter 觸發(fā)時(shí),會(huì)通知 watcher,從而使它關(guān)聯(lián)的組件重新渲染。

那么返回給外部的,實(shí)際是一個(gè)經(jīng)過篡改的,經(jīng)過了代理的數(shù)據(jù)對(duì)象。

如果初始值沒給這個(gè)變量Vue還能監(jiān)聽嗎?

這里面有個(gè)新手易犯的問題是:一開始傳進(jìn)數(shù)據(jù)對(duì)象時(shí)忘記傳這個(gè)變量或無法傳這個(gè)變量。

由于 JavaScript 的限制,Vue 不能檢測(cè)數(shù)組和對(duì)象的變化。

如果后面使用了這個(gè)變量,那么后面對(duì)這個(gè)變量進(jìn)行更新時(shí)頁面不會(huì)變化的,因?yàn)関ue根本沒監(jiān)聽這個(gè)對(duì)象。

解決辦法:

(1)一開始就傳入這個(gè)變量;

(2)對(duì)于對(duì)象:使用Vue.set或vm.$ set在使用之前監(jiān)聽變量;

(3)對(duì)于數(shù)組,除了使用對(duì)象的Vue.set或和vm.$set 方法。尤雨溪其實(shí)對(duì)數(shù)組的如下方法進(jìn)行了封裝,使用這些方法的時(shí)候已經(jīng)進(jìn)行了set監(jiān)聽。

  • push()
  • pop()
  • shift()
  • unshift()
  • splice()
  • sort()
  • reverse()

有一個(gè)神奇的測(cè)試題:

<div id="app">
? ? <span class=span-a>
? ? ? {{obj.a}}?
? ? </span>
? ? <span class=span-b>
? ? ? {{obj.b}}
? ? </span>
? </div>
var app = new Vue({
? el: '#app',
? data: {
? ? obj: {
? ? ? a: 'a',
? ? }
? },
})
app.obj.a = 'a2'
app.obj.b = 'b'

最終 span-a 和 span-b 中分別展示什么字符串?答案是:a2和b

原因是視圖在顯示 span-a 的 a2 時(shí),順便更新了 span-b

視圖更新其實(shí)是異步的。

1、當(dāng)我們讓 a 從 ‘a1’ 變成 ‘a2’ 時(shí),Vue 會(huì)監(jiān)聽到這個(gè)變化,但是 Vue 并不能馬上更新視圖,因?yàn)?Vue 是使用 Object.defineProperty 這樣的方式來監(jiān)聽變化的,監(jiān)聽到變化后會(huì)創(chuàng)建一個(gè)視圖更新任務(wù)到任務(wù)隊(duì)列里。(文檔有寫)

2、所以在視圖更新之前,要先把余下的代碼運(yùn)行完才行,也就是會(huì)運(yùn)行 b = ‘b’。

3、等到視圖更新的時(shí)候,由于 Vue 會(huì)去做 diff(文檔有寫),于是 Vue 就會(huì)發(fā)現(xiàn) a 和 b 都變了,自然會(huì)去更新 span-a 和 span-b。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • 記錄一個(gè)van-list不斷onLoad加載的坑及解決

    記錄一個(gè)van-list不斷onLoad加載的坑及解決

    這篇文章主要介紹了記錄一個(gè)van-list不斷onLoad加載的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue Render中slots的使用的實(shí)例代碼

    vue Render中slots的使用的實(shí)例代碼

    本篇文章主要介紹了vue Render中slots的使用的實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-07-07
  • Vue.js實(shí)現(xiàn)的表格增加刪除demo示例

    Vue.js實(shí)現(xiàn)的表格增加刪除demo示例

    這篇文章主要介紹了Vue.js實(shí)現(xiàn)的表格增加刪除demo,結(jié)合實(shí)例形式分析了vue.js數(shù)據(jù)綁定及元素增加、刪除等相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05
  • VUE跨域詳解以及常用解決跨域的方法

    VUE跨域詳解以及常用解決跨域的方法

    跨域指瀏覽器不允許當(dāng)前頁面的所在的源去請(qǐng)求另一個(gè)源的數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于VUE跨域詳解以及常用解決跨域的方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • vue中的eventBus會(huì)不會(huì)產(chǎn)生內(nèi)存泄漏你知道嗎

    vue中的eventBus會(huì)不會(huì)產(chǎn)生內(nèi)存泄漏你知道嗎

    這篇文章主要為大家詳細(xì)介紹了vue中的eventBus會(huì)不會(huì)產(chǎn)生內(nèi)存泄漏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • vue-content-loader內(nèi)容加載器的使用方法

    vue-content-loader內(nèi)容加載器的使用方法

    這篇文章主要介紹了vue-content-loader內(nèi)容加載器的使用方法,本文分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-08-08
  • 解決el-upload批量上傳只執(zhí)行一次成功回調(diào)on-success的問題

    解決el-upload批量上傳只執(zhí)行一次成功回調(diào)on-success的問題

    這篇文章主要介紹了解決el-upload批量上傳只執(zhí)行一次成功回調(diào)on-success的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue封裝--如何將數(shù)字轉(zhuǎn)換成萬

    Vue封裝--如何將數(shù)字轉(zhuǎn)換成萬

    這篇文章主要介紹了Vue封裝--將數(shù)字轉(zhuǎn)換成萬的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue請(qǐng)求按順序執(zhí)行的示例詳解

    vue請(qǐng)求按順序執(zhí)行的示例詳解

    我們有時(shí)候會(huì)碰到這種情況,需要連續(xù)發(fā)送兩個(gè)請(qǐng)求,第二個(gè)請(qǐng)求需要用第一個(gè)請(qǐng)求的某個(gè)返回值作為參數(shù)來作為第二個(gè)請(qǐng)求的請(qǐng)求參數(shù),這篇文章主要介紹了vue請(qǐng)求如何按順序執(zhí)行,需要的朋友可以參考下
    2023-12-12
  • vue-router實(shí)現(xiàn)嵌套路由的講解

    vue-router實(shí)現(xiàn)嵌套路由的講解

    今天小編就為大家分享一篇關(guān)于vue-router實(shí)現(xiàn)嵌套路由的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01

最新評(píng)論