本篇文章主要介紹了VueJS元件之間透過props互動及驗證的方式,具有一定的參考價值,有興趣的小夥伴們可以參考一下。
props 是父元件用來傳遞資料的一個自訂屬性。父元件的資料需要透過 props 把資料傳給子元件,子元件需要明確地用 props 選項宣告 "prop"。
父元件透過props將資料傳遞給子元件
HTML
#<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Vue 测试实例 - 菜鸟教程(runoob.com)</title> <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script> </head> <body> <p id="app"> <child message="hello world!">props传递给子组件</child> </p> <script> // Vue.component('child', { // 声明 props props: ['message'], // 同样也可以在 vm 实例中像 “this.message” 这样使用 template: '<h1>{{ message }}</h1>' }) // 创建根实例 new Vue({ el: '#app' }) </script> </body> </html>
動態props組成資料傳遞
類似於用v-bind 綁定HTML 特性到一個表達式,也可以用v-bind 動態綁定props 的值到父組件的資料中。每當父元件的資料變更時,該變更也會傳導給子元件:HTML#
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Vue 测试实例 - 菜鸟教程(runoob.com)</title> <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script> </head> <body> <p id="app"> <p> <input v-model="parentMsg"> <br> <child v-bind:message="parentMsg"></child> </p> </p> <script> // 注册 Vue.component('child', { // 声明 props props: ['message'], // 同样也可以在 vm 实例中像 “this.message” 这样使用 template: '<span>{{ message }}</span>' }) // 创建根实例 new Vue({ el: '#app', data: { parentMsg: '父组件内容' } }) </script> </body> </html>
## 效果如圖:
v-bind 指令將todo 傳到每個重複的元件中
HTML
##
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Vue 测试实例 - 菜鸟教程(runoob.com)</title> <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script> </head> <body> <p id="app"> <ol> <todo-item v-for="item in sites" v-bind:todo="item"></todo-item> </ol> </p> <script> Vue.component('todo-item', { props: ['todo'], template: '<li>{{ todo.text }}</li>' }) new Vue({ el: '#app', data: { sites: [ { text: 'Runoob' }, { text: 'Google' }, { text: 'Taobao' } ] } }) </script> </body> </html>
效果如下:
注意: props 是單向綁定的:當父元件的屬性變化時,將傳導給子元件,但是不會反過來。
JS
Vue.component('example', { props: { // 基础类型检测 (`null` 意思是任何类型都可以) propA: Number, // 多种类型 propB: [String, Number], // 必传且是字符串 propC: { type: String, required: true }, // 数字,有默认值 propD: { type: Number, default: 100 }, // 数组/对象的默认值应当由一个工厂函数返回 propE: { type: Object, default: function () { return { message: 'hello' } } }, // 自定义验证函数 propF: { validator: function (value) { return value > 10 } } } })
type 也可以是一個自訂建構器,使用instanceof 來偵測。
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
Vue中封裝input元件的介紹
#########Vue元件通訊實作的介紹#### ###########Vue2.0 多Tab切換元件的封裝介紹###########################以上是VueJS元件之間透過props互動及驗證的方式的詳細內容。更多資訊請關注PHP中文網其他相關文章!