W3Cschool
恭喜您成為首批注冊(cè)用戶(hù)
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
behaviors 是用于組件間代碼共享的特性,類(lèi)似于一些編程語(yǔ)言中的 “mixins” 或 “traits”。
每個(gè) behavior 可以包含一組屬性、數(shù)據(jù)、生命周期函數(shù)和方法。組件引用它時(shí),它的屬性、數(shù)據(jù)和方法會(huì)被合并到組件中,生命周期函數(shù)也會(huì)在對(duì)應(yīng)時(shí)機(jī)被調(diào)用。 每個(gè)組件可以引用多個(gè) behavior ,behavior 也可以引用其它 behavior 。
詳細(xì)的參數(shù)含義和使用請(qǐng)參考 Behavior 參考文檔。
組件引用時(shí),在 behaviors 定義段中將它們逐個(gè)列出即可。
代碼示例:
// my-component.js
var myBehavior = require('my-behavior')
Component({
behaviors: [myBehavior],
properties: {
myProperty: {
type: String
}
},
data: {
myData: 'my-component-data'
},
created: function () {
console.log('[my-component] created')
},
attached: function () {
console.log('[my-component] attached')
},
ready: function () {
console.log('[my-component] ready')
},
methods: {
myMethod: function () {
console.log('[my-component] log by myMethod')
},
}
})
在上例中, my-component 組件定義中加入了 my-behavior,
而 my-behavior 結(jié)構(gòu)為:
這將使 my-component 最終結(jié)構(gòu)為:
當(dāng)組件觸發(fā)生命周期時(shí),上例生命周期函數(shù)執(zhí)行順序?yàn)椋?/p>
詳細(xì)規(guī)則參考 同名字段的覆蓋和組合規(guī)則。
組件和它引用的 behavior 中可以包含同名的字段,對(duì)這些字段的處理方法如下:
代碼示例:
在開(kāi)發(fā)者工具中預(yù)覽效果
自定義組件可以通過(guò)引用內(nèi)置的 behavior 來(lái)獲得內(nèi)置組件的一些行為。
Component({
behaviors: ['wx://form-field']
})
在上例中, wx://form-field 代表一個(gè)內(nèi)置 behavior ,它使得這個(gè)自定義組件有類(lèi)似于表單控件的行為。
內(nèi)置 behavior 往往會(huì)為組件添加一些屬性。在沒(méi)有特殊說(shuō)明時(shí),組件可以覆蓋這些屬性來(lái)改變它的 type 或添加 observer 。
使自定義組件有類(lèi)似于表單控件的行為。 form 組件可以識(shí)別這些自定義組件,并在 submit 事件中返回組件的字段名及其對(duì)應(yīng)字段值。
詳細(xì)用法以及代碼示例可見(jiàn):form 組件參考文檔
從基礎(chǔ)庫(kù)版本 2.10.2 開(kāi)始提供支持。
使 form 組件可以識(shí)別到這個(gè)自定義組件內(nèi)部的所有表單控件。
詳細(xì)用法以及代碼示例可見(jiàn):form 組件參考文檔
從基礎(chǔ)庫(kù)版本 2.10.3 開(kāi)始提供支持。
使 form 組件可以識(shí)別到這個(gè)自定義組件內(nèi)部的 button 。如果自定義組件內(nèi)部有設(shè)置了 form-type 的 button ,它將被組件外的 form 接受。
詳細(xì)用法以及代碼示例可見(jiàn):form 組件參考文檔
從基礎(chǔ)庫(kù)版本 2.2.3 開(kāi)始提供支持。
使自定義組件支持 export 定義段。這個(gè)定義段可以用于指定組件被 selectComponent 調(diào)用時(shí)的返回值。
詳細(xì)用法以及代碼示例可見(jiàn):selectComponent 參考文檔
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話(huà):173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: