欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序組件通信和behavior使用詳解

 更新時間:2022年08月15日 16:40:27   作者:亦世凡華  
behaviors是小程序中,用于實(shí)現(xiàn)組件間代碼共享的特性,類似于 Vue.js 中的 “mixins”,這篇文章主要介紹了微信小程序組件通信和behavior使用,需要的朋友可以參考下

??引言

?經(jīng)過web前端開發(fā)的學(xué)習(xí),相信大家對于前端開發(fā)有了一定深入的了解,今天我開設(shè)了微信小程序?qū)?,主要想從移動端開發(fā)方向進(jìn)一步發(fā)展,而對于我來說寫移動端博文的第一站就是小程序開發(fā),希望看到我文章的朋友能對你有所幫助。

???組件通信

??父子組件的通信方式

屬性綁定:用于父組件向子組件的指定屬性設(shè)置數(shù)據(jù),僅能設(shè)置JSON兼容的數(shù)據(jù)。

屬性綁定用于實(shí)現(xiàn)父向子傳值,而且只能傳遞普通類型的數(shù)據(jù),無法將方法傳遞給子組件。

事件綁定:用于子組件向父組件傳遞數(shù)據(jù),可以傳遞任意數(shù)據(jù)。

事件綁定用于實(shí)現(xiàn)子向父傳值,可以傳遞任何類型的數(shù)據(jù),其使用步驟如下:

父組件的.js中,定義一個函數(shù),這個函數(shù)即將通過自定義事件的形式,傳遞給子組件

//和data平齊
syscCount(){
},

父組件的.wxml中,通過自定義事件的形式,將步驟一定義的函數(shù)引用傳遞給子組件

<mydemo4 count="{{count}}" bind:sysc="syscCount"></mydemo4>

子組件的.js中,通過調(diào)用this.triggerEvent('自定義事件名稱',{/*參數(shù)對象*/}),將數(shù)據(jù)發(fā)送到父組件

methods: {
  addCount(){
    this.setData({
      count:this.properties.count + 1
    })
    // 觸發(fā)自定義事件,將數(shù)值同步給父組件
    this.triggerEvent('sysc',{value:this.properties.count})
  }
}

父組件的.js中,通過e.detail獲取到子組件傳遞過來的數(shù)據(jù)

//和data平齊
syscCount(e){
  console.log('sysCount!!!');
  // console.log(e.detail.value);
  this.setData({
    count:e.detail.value
  })
},

獲取組件實(shí)例:父組件可以通過 this.selectComponent() 獲取子組件實(shí)例對象,這樣可以直接訪問子組件的任意數(shù)據(jù)和方法。

可在父組件里調(diào)用 this.selectComponent( id 或 class選擇器),獲取子組件的實(shí)例對象,從而直接訪問子組件的任意數(shù)據(jù)和方法。調(diào)用時需要傳入一個選擇器。

//.wxml
<mydemo4 count="{{count}}" bind:sysc="syscCount" class="child" id="childId"></mydemo4>
<view>-------</view>
<view>父組件中,count的值是:{{count}}</view>
<button bindtap="getChild">獲取子組件的實(shí)例對象</button>
 
//.js
getChild(){ //按鈕的 tap 處理函數(shù)
  // 切記下面參數(shù)不能傳遞標(biāo)簽選擇器,只能的id或者class,否則會返回 null
  const child = this.selectComponent('.child')
  // console.log(child);
  // child.setData({
  //   count:child.properties.count + 1
  // })
  child.addCount()
}

???behaviors

behaviors是小程序中,用于實(shí)現(xiàn)組件間代碼共享的特性,類似于 Vue.js 中的 “mixins”。

??behaviors工作方式

每個 behaviors 可以包含一組屬性、數(shù)據(jù)、生命周期函數(shù)和方法。組件引用它時,它的屬性、數(shù)據(jù)和方法會被合并到組件中,每個組件可以引用多個behaviors,behavior也可以引用其它behavior。

??創(chuàng)建 behavior

調(diào)用 Behavior (Object object) 方法,即可創(chuàng)建一個共享的 behavior 實(shí)例對象,供所有組件使用:

//調(diào)用 Behavior() 方法,創(chuàng)建實(shí)例對象并使用 module.exports 把 behavior 實(shí)例對象共享出去
module.exports = Behavior({
  // 屬性節(jié)點(diǎn)
  properties:{},
  // 私有數(shù)據(jù)節(jié)點(diǎn)
  data:{
    username:'zs'
  },
  // 事件處理函數(shù)和自定義方法
  methods:{},
  // 其他節(jié)點(diǎn)。。。
})

??導(dǎo)入并使用 behavior

在組件中,使用 require() 方法導(dǎo)入需要的 behavior,掛載后即可訪問 behavior 中的數(shù)據(jù)和方法。

// 使用 require() 導(dǎo)入需要的自定義 behavior 模塊
const myBehavior = require('../../behaviors/my-behaviors')
 
Component({
  // 將導(dǎo)入的 behavior 實(shí)例對象掛載到 behavior 數(shù)組節(jié)點(diǎn)中,即可生效
  behaviors:[myBehavior],
})

??behavior中所有可用的節(jié)點(diǎn)

可用的節(jié)點(diǎn)類型可選項(xiàng)是否必須描述
propertiesObject Map同組件的屬性
dataObject同組件的數(shù)據(jù)
methodsObject同自定義組件的方法
behaviorsString Array引入其它的 behavior
createdFunction生命周期函數(shù)
attachedFunction生命周期函數(shù)
readyFunction生命周期函數(shù)
movedFunction生命周期函數(shù)
detachedFunction生命周期函數(shù)

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

組件和它引用的 behavior 中可以包含同名字段,對這些處理的字段有如下三種同名處理規(guī)則:

同名的數(shù)據(jù)字段(data):

若同名的數(shù)據(jù)字段都是對象類型,會進(jìn)行對象合并;

其余情況會進(jìn)行數(shù)據(jù)覆蓋,覆蓋規(guī)則為: 引用者 behavior > 被引用的 behavior 、 靠后的 behavior > 靠前的 behavior。(優(yōu)先級高的覆蓋優(yōu)先級低的,最大的為優(yōu)先級最高);

同名的屬性(properties)或方法(methods)

若組件本身有這個屬性或方法,則組件的屬性或方法會覆蓋 behavior 中的同名屬性或方法;

若組件本身無這個屬性或方法,則在組件的 behaviors 字段中定義靠后的 behavior 的屬性或方法會覆蓋靠前的同名屬性或方法;

在 2 的基礎(chǔ)上,若存在嵌套引用 behavior 的情況,則規(guī)則為:引用者 behavior 覆蓋 被引用的 behavior 中的同名屬性或方法。

同名的生命周期函數(shù)

對于不同的生命周期函數(shù)之間,遵循組件生命周期函數(shù)的執(zhí)行順序;

對于同種生命周期函數(shù)和同字段 observers ,遵循如下規(guī)則:

behavior 優(yōu)先于組件執(zhí)行;

被引用的 behavior 優(yōu)先于 引用者 behavior 執(zhí)行;

靠前的 behavior 優(yōu)先于 靠后的 behavior 執(zhí)行;

如果同一個 behavior 被一個組件多次引用,它定義的生命周期函數(shù)和 observers 不會重復(fù)執(zhí)行。

到此這篇關(guān)于微信小程序組件通信和behavior使用的文章就介紹到這了,更多相關(guān)小程序組件通信內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • taro 實(shí)現(xiàn)購物車邏輯的實(shí)例代碼

    taro 實(shí)現(xiàn)購物車邏輯的實(shí)例代碼

    這篇文章主要介紹了taro 實(shí)現(xiàn)購物車邏輯,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • javascript event 事件解析

    javascript event 事件解析

    描述 event代表事件的狀態(tài),例如觸發(fā)event對象的元素、鼠標(biāo)的位置及狀態(tài)、按下的鍵等等。
    2011-01-01
  • JavaScript簡單拖拽效果(1)

    JavaScript簡單拖拽效果(1)

    這篇文章主要為大家詳細(xì)介紹了JavaScript簡單拖拽效果 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • JavaScript自定義分頁樣式

    JavaScript自定義分頁樣式

    這篇文章主要為大家詳細(xì)介紹了JavaScript自定義分頁樣式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • javascript下對于事件、事件流、事件觸發(fā)的順序隨便說說

    javascript下對于事件、事件流、事件觸發(fā)的順序隨便說說

    向同一個標(biāo)簽 動態(tài)的添加事件是 執(zhí)行的順序在ie和其他非ie內(nèi)核的瀏覽器有所不同 ie是“先進(jìn)先出 ” 就是最先添加的最先執(zhí)行,其他非ie內(nèi)核的瀏覽器是 “先進(jìn)后出”,就是 最后添加的事件 先執(zhí)行。
    2010-07-07
  • JS模態(tài)窗口返回值兼容問題的完美解決方法

    JS模態(tài)窗口返回值兼容問題的完美解決方法

    下面小編就為大家?guī)硪黄狫S模態(tài)窗口返回值兼容問題的完美解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • JS浮點(diǎn)數(shù)運(yùn)算結(jié)果不精確的Bug解決

    JS浮點(diǎn)數(shù)運(yùn)算結(jié)果不精確的Bug解決

    這篇文章主要給大家介紹了關(guān)于JS浮點(diǎn)數(shù)運(yùn)算結(jié)果不精確的Bug解決,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用JS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 微信小程序網(wǎng)絡(luò)層封裝的實(shí)現(xiàn)(promise, 登錄鎖)

    微信小程序網(wǎng)絡(luò)層封裝的實(shí)現(xiàn)(promise, 登錄鎖)

    這篇文章主要介紹了微信小程序網(wǎng)絡(luò)層封裝(promise, 登錄鎖),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • JavaScript 的繼承

    JavaScript 的繼承

    大家都知道,C#中使用的是傳統(tǒng)的類繼承是很簡單,但在JS中,可就沒這么簡單了,因?yàn)樗褂玫氖窃?prototype )繼承,實(shí)現(xiàn)起來相對復(fù)雜了一點(diǎn)。
    2011-10-10
  • JavaScript 手動實(shí)現(xiàn)instanceof的方法

    JavaScript 手動實(shí)現(xiàn)instanceof的方法

    instanceof運(yùn)算符用于檢測構(gòu)造函數(shù)的prototype屬性是否出現(xiàn)在某個實(shí)例對象的原型鏈上,本文重點(diǎn)給大家介紹JavaScript手動實(shí)現(xiàn)instanceof的問題,感興趣的朋友跟隨小編一起看看吧
    2021-10-10

最新評論