您好,登錄后才能下訂單哦!
這篇文章主要講解了“vuejs中data與props有哪些區別”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“vuejs中data與props有哪些區別”吧!
vuejs中data與props的區別:1、data不需要用戶(開發者)傳值,自身維護;而props需要用戶(開發者)傳值。2、data上的數據都是可讀可寫的;而props上的數據只可以讀的,無法重新賦值。
本教程操作環境:windows7系統、vue2.9.6版,DELL G3電腦。
在使用Vue.js
的過程中,經常會遇到 data
和 props
。今天就來探索一下二者的區別。
data
類型: Object
| Function
限制 :組件的定義只接受 Function
Vue
實例的數據對象。Vue
將會遞歸將 data
的屬性轉換為 getter/setter
,從而讓 data
的屬性能夠響應數據變化。對象必須是純粹的對象 (含有零個或多個的 key/value
對):瀏覽器 API
創建的原生對象,原型上的屬性會被忽略。大概來說,data
應該只能是數據 - 不推薦觀察擁有狀態行為的對象。
例:
var data = { a: 1 } // 直接創建一個實例 var vm = new Vue({ data: data }) vm.a // => 1 vm.$data === data // => true // Vue.extend() 中 data 必須是函數 var Component = Vue.extend({ data: function () { return { a: 1 } } })
props
類型:Array<string>
| Object
props
可以是數組或對象,用于接收來自父組件的數據。props
可以是簡單的數組,或者使用對象作為替代,對象允許配置高級選項,如類型檢測、自定義驗證和設置默認值。
例 :
// 簡單語法 Vue.component('props-demo-simple', { props: ['size', 'myMessage'] }) // 對象語法,提供驗證 Vue.component('props-demo-advanced', { props: { // 檢測類型 height: Number, // 檢測類型 + 其他驗證 age: { type: Number, default: 0, required: true, validator: function (value) { return value >= 0 } } } })
區別一:
data
不需要用戶(開發者)傳值,自身維護
props
需要用戶(開發者)傳值
區別二:
1、data上的數據都是可讀可寫的,
2、props上的數據只可以讀的,無法重新賦值
感謝各位的閱讀,以上就是“vuejs中data與props有哪些區別”的內容了,經過本文的學習后,相信大家對vuejs中data與props有哪些區別這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。