關(guān)于Vue?"__ob__:Observer"屬性的解決方案詳析
問題描述
- 我們操作 Vue 數(shù)據(jù)的時候,經(jīng)常會看到這個屬性:
__ob__:Observer
- 在我們操作這個數(shù)據(jù)的時候,如果想要單獨拿這個數(shù)據(jù)里面的值,就會返回
undefined
- 經(jīng)過我在網(wǎng)上查找相關(guān)資料,發(fā)現(xiàn)
__ob__:Observer
是 Vue 中一個非常重要的知識點
原因分析:
那么什么是數(shù)據(jù)對象的
__ob__
屬性呢?
其實 __ob__:Observer
這些數(shù)據(jù),是 Vue 框架對數(shù)據(jù)設(shè)置的監(jiān)控器,一般是 不可以被枚舉
的
解決方案:
下面是我在網(wǎng)上查資料找的幾點解決方案,希望可以幫到大家:
第一種: __ob__: Observer
是 Vue 對數(shù)據(jù)監(jiān)控添加的屬性,如果想去掉可以采用對象賦值的方式。
舉個例子:Object.assign({ },this.owner)
擴展知識:Object.assign() 方法將所有可枚舉和自有屬性從一個或多個源對象復(fù)制到目標對象,返回修改后的對象。
第二種: 比如說 list 里面存放的就是那些帶有 __ob__:Observer
的數(shù)據(jù),那么可以使用 JSON.parse(JSON.stringify(this.list))
來進行解決
第三種: 直接操作數(shù)據(jù)
// 將后端返回的數(shù)據(jù),賦值給我們定義的變量 // 舉個例子:我們定義的變量叫做 tableData this.tableData = res.data; // 我們把后端返回的數(shù)據(jù),賦值給我們的變量 this.tableData 如果我們是在控制臺輸出: console.log(this.tableData.id) // 就會返回 undefined 但是如果我們加上索引: console.log(this.tableData[0].id) // 就會得到我們想要的 id 了
總結(jié)
到此這篇關(guān)于關(guān)于Vue "__ob__:Observer"屬性的解決方案的文章就介紹到這了,更多相關(guān)Vue "__ob__:Observer"屬性解決內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue中__ob__:?Observer的踩坑記錄
- Vue之Dep和Observer的用法及說明
- vue3?圖片懶加載的兩種方式、IntersectionObserver和useIntersectionObserver實例詳解
- Vue2?Observer實例dep和閉包中dep區(qū)別詳解
- vue中關(guān)于_ob_:observer的處理方式
- Vue數(shù)組中出現(xiàn)__ob__:Observer無法取值問題的解決方法
- Vue響應(yīng)式原理Observer、Dep、Watcher理解
- vue中{__ob__: observer}對象轉(zhuǎn)化為數(shù)組進行遍歷方式
相關(guān)文章
關(guān)于ElementUI自定義Table支持render
這篇文章主要介紹了關(guān)于ElementUI自定義Table支持render,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10Vue環(huán)境搭建+VSCode+Win10的詳細教程
這篇文章主要介紹了Vue環(huán)境搭建+VSCode+Win10,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08最全vue的vue-amap使用高德地圖插件畫多邊形范圍的示例代碼
這篇文章主要介紹了最全vue的vue-amap使用高德地圖插件畫多邊形范圍,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07vue video和vue-video-player實現(xiàn)視頻鋪滿教程
這篇文章主要介紹了vue video和vue-video-player實現(xiàn)視頻鋪滿教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10使用Vue3新特性構(gòu)建動態(tài)表單的方法詳解
傳統(tǒng)的表單開發(fā)通常需要編寫大量的重復(fù)代碼,例如處理用戶輸入、驗證數(shù)據(jù)、更新 UI 等等,為了簡化開發(fā),我們可以借助 Vue 3 的新特性,例如組合式 API 和 ref 對象,所以本文我們將一起學(xué)習(xí)如何使用 Vue 3 的新特性構(gòu)建一個更加靈活、可擴展的動態(tài)表單2024-06-06element-UI el-table修改input值視圖不更新問題
這篇文章主要介紹了element-UI el-table修改input值視圖不更新問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02