日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
創(chuàng)新互聯(lián)小程序教程:微信小程序behaviors

behaviors

behaviors 是用于組件間代碼共享的特性,類似于一些編程語言中的 “mixins” 或 “traits”。

洛南ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!

每個 behavior 可以包含一組屬性、數(shù)據(jù)、生命周期函數(shù)和方法。組件引用它時,它的屬性、數(shù)據(jù)和方法會被合并到組件中,生命周期函數(shù)也會在對應(yīng)時機被調(diào)用。 每個組件可以引用多個 behavior ,behavior 也可以引用其它 behavior 。

詳細的參數(shù)含義和使用請參考 Behavior 參考文檔。

組件中使用

組件引用時,在 behaviors 定義段中將它們逐個列出即可。

代碼示例:

// 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)為:

  • 屬性:myBehaviorProperty
  • 數(shù)據(jù)字段:myBehaviorData
  • 方法:myBehaviorMethod
  • 生命周期函數(shù):attached、created、ready

這將使 my-component 最終結(jié)構(gòu)為:

  • 屬性:myBehaviorProperty、myProperty
  • 數(shù)據(jù)字段:myBehaviorData、myData
  • 方法:myBehaviorMethod、myMethod
  • 生命周期函數(shù):attached、created、ready

當(dāng)組件觸發(fā)生命周期時,上例生命周期函數(shù)執(zhí)行順序為:

  1. [my-behavior] created
  2. [my-component] created
  3. [my-behavior] attached
  4. [my-component] attached
  5. [my-behavior] ready
  6. [my-component] ready

詳細規(guī)則參考 同名字段的覆蓋和組合規(guī)則。

同名字段的覆蓋和組合規(guī)則

組件和它引用的 behavior 中可以包含同名的字段,對這些字段的處理方法如下:

  • 如果有同名的屬性 (properties) 或方法 (methods):若組件本身有這個屬性或方法,則組件的屬性或方法會覆蓋 behavior 中的同名屬性或方法;若組件本身無這個屬性或方法,則在組件的 behaviors 字段中定義靠后的 behavior 的屬性或方法會覆蓋靠前的同名屬性或方法;在 2 的基礎(chǔ)上,若存在嵌套引用 behavior 的情況,則規(guī)則為:父 behavior 覆蓋 子 behavior 中的同名屬性或方法。
  • 如果有同名的數(shù)據(jù)字段 (data):若同名的數(shù)據(jù)字段都是對象類型,會進行對象合并;其余情況會進行數(shù)據(jù)覆蓋,覆蓋規(guī)則為:組件 > 父 behavior > 子 behavior 、 靠后的 behavior > 靠前的 behavior。(優(yōu)先級高的覆蓋優(yōu)先級低的,最大的為優(yōu)先級最高)
  • 生命周期函數(shù)不會相互覆蓋,而是在對應(yīng)觸發(fā)時機被逐個調(diào)用:對于不同的生命周期函數(shù)之間,遵循組件生命周期函數(shù)的執(zhí)行順序;對于同種生命周期函數(shù),遵循如下規(guī)則:behavior 優(yōu)先于組件執(zhí)行;子 behavior 優(yōu)先于 父 behavior 執(zhí)行;靠前的 behavior 優(yōu)先于 靠后的 behavior 執(zhí)行;如果同一個 behavior 被一個組件多次引用,它定義的生命周期函數(shù)只會被執(zhí)行一次。

代碼示例:

在開發(fā)者工具中預(yù)覽效果

內(nèi)置 behaviors

自定義組件可以通過引用內(nèi)置的 behavior 來獲得內(nèi)置組件的一些行為。

Component({
  behaviors: ['wx://form-field']
})

在上例中, wx://form-field 代表一個內(nèi)置 behavior ,它使得這個自定義組件有類似于表單控件的行為。

內(nèi)置 behavior 往往會為組件添加一些屬性。在沒有特殊說明時,組件可以覆蓋這些屬性來改變它的 type 或添加 observer 。

wx://form-field

使自定義組件有類似于表單控件的行為。 form 組件可以識別這些自定義組件,并在 submit 事件中返回組件的字段名及其對應(yīng)字段值。

詳細用法以及代碼示例可見:form 組件參考文檔

wx://form-field-group

從基礎(chǔ)庫版本 2.10.2 開始提供支持。

使 form 組件可以識別到這個自定義組件內(nèi)部的所有表單控件。

詳細用法以及代碼示例可見:form 組件參考文檔

wx://form-field-button

從基礎(chǔ)庫版本 2.10.3 開始提供支持。

使 form 組件可以識別到這個自定義組件內(nèi)部的 button 。如果自定義組件內(nèi)部有設(shè)置了 form-type 的 button ,它將被組件外的 form 接受。

詳細用法以及代碼示例可見:form 組件參考文檔

wx://component-export

從基礎(chǔ)庫版本 2.2.3 開始提供支持。

使自定義組件支持 export 定義段。這個定義段可以用于指定組件被 selectComponent 調(diào)用時的返回值。

詳細用法以及代碼示例可見:selectComponent 參考文檔


新聞標(biāo)題:創(chuàng)新互聯(lián)小程序教程:微信小程序behaviors
URL鏈接:http://www.dlmjj.cn/article/dhpdici.html