微信小程序自定義組件和通信的方法
1、基本知識(shí)
開發(fā)中常見的組件主要分為 公共組件 和 頁面組件 兩種,因此注冊(cè)組件的方式也分為兩種:
- 全局注冊(cè):在
app.json文件中配置usingComponents節(jié)點(diǎn)進(jìn)行引用聲明,注冊(cè)后可在任意組件使用 - 局部注冊(cè):在
頁面.json文件中配置usingComponents節(jié)點(diǎn)進(jìn)行引用聲明,只可在當(dāng)前頁面使用
在組件的 .js 中,需要調(diào)用 Component 方法創(chuàng)建自定義組件,Component 中有以下兩個(gè)屬性:
data數(shù)據(jù):組件的內(nèi)部數(shù)據(jù)methods方法:在組件中事件處理程序需要寫到methods中才可以其他……
2、Properties屬性
屬性 Properties 是指組件的對(duì)外屬性,主要用來接收組件使用者傳遞給組件內(nèi)部的數(shù)據(jù),和 data 一同用于組件的模板渲染
Component({
properties: {
// 如果需要接收傳遞的屬性,有兩種方式:全寫、簡(jiǎn)寫
label: String // 簡(jiǎn)寫
label: {
// type 組件使用者傳遞的數(shù)據(jù)類型
// 數(shù)據(jù)類型:String、Number、Boolean、Object、Array
// 也可以設(shè)置為 null,表示不限制類型
type: String,
value: ''
},
// 文字顯示位置
position: {
type: String,
value: 'right'
}
}
})3、slot插槽
在使用基礎(chǔ)組件時(shí),可以給組件傳遞子節(jié)點(diǎn)傳遞內(nèi)容,從而將內(nèi)容展示到頁面中,自定義組件也可以接收子節(jié)點(diǎn)內(nèi)容
只不過在組件模板中需要定義 <slot /> 節(jié)點(diǎn),用于承載組件引用時(shí)提供的子節(jié)點(diǎn)
默認(rèn)情況下,一個(gè)組件的 wxml 中只能有一個(gè) slot 。需要使用多 slot 時(shí),可以在組件 js 中聲明啟用。
同時(shí)需要給 slot 添加 name 來區(qū)分不同的 slot,給子節(jié)點(diǎn)內(nèi)容添加 slot 屬性來將節(jié)點(diǎn)插入到 對(duì)應(yīng)的 slot 中
Component({
options: {
// 啟用多 slot 支持
multipleSlots: true
}
})<!-- 子組件 --> <view> <slot name="slot-top" /> <!-- slot 就是用來接收、承載子節(jié)點(diǎn)內(nèi)容 --> <!-- slot 只是一個(gè)占位符,子節(jié)點(diǎn)內(nèi)容會(huì)將 slot 進(jìn)行替換 --> <!-- 默認(rèn)插槽 --> <view><slot /></view> <slot name="slot-bottom" /> </view>
<custom01> <text slot="slot-top">我需要顯示到頂部</text> <!-- 默認(rèn)情況下,自定義組件的子節(jié)點(diǎn)內(nèi)容不會(huì)進(jìn)行展示 --> <!-- 如果想內(nèi)容進(jìn)行展示,需要再組件模板中定義 slot 節(jié)點(diǎn) --> 我是子節(jié)點(diǎn)內(nèi)容 <text slot="slot-bottom">我需要顯示到低部</text> </custom01>
4、組件樣式隔離
默認(rèn)情況下,自定義組件的樣式只受到自定義組件 wxss 的影響。除非以下兩種情況:
app.wxss或頁面. wxss中使用了標(biāo)簽名(view)選擇器(或一些其他特殊選擇器)來直接指定樣式,這些選擇器會(huì)影響到頁面和全部組件。通常情況下這是不推薦的做法。- 指定特殊的樣式隔離選項(xiàng)
styleIsolation,支持以下取值: isolated表示啟用樣式隔離,在自定義組件內(nèi)外,使用 class 指定的樣式將不會(huì)相互影響(一般情況下的默認(rèn)值);apply-shared表示頁面 wxss 樣式將影響到自定義組件,但自定義組件 wxss 中指定的樣式不會(huì)影響頁面;shared表示頁面 wxss 樣式將影響到自定義組件,自定義組件 wxss 中指定的樣式也會(huì)影響頁面和其他設(shè)置了 apply-shared 或 shared 的自定義組件。
Component({
options: {
styleIsolation: 'isolated'
}
})5、組件間通信
- 父往子傳值:
Properties - 子往父?jìng)髦担鹤远x事件、獲取組件實(shí)例
5.1 自定義事件
- 自定義組件觸發(fā)事件時(shí),需要使用
triggerEvent方法發(fā)射一個(gè)自定義的事件 - 自定義組件標(biāo)簽上通過
bind方法監(jiān)聽發(fā)射的事件
子組件觸發(fā)事件:
<!-- 在子組件中 --> <button type="primary" plain bindtap="sendData">傳遞數(shù)據(jù)</button>
// 在子組件中
Component({
// 組件的初始數(shù)據(jù)
data: {
num: 666
},
// 組件的方法列表
methods: {
// 將數(shù)據(jù)傳遞給父組件
sendData () {
// 如果需要將數(shù)據(jù)傳遞給父組件
// 需要使用 triggerEvent 發(fā)射自定義事件
// 第二個(gè)參數(shù),是攜帶的參數(shù)
this.triggerEvent('myevent', this.data.num)
}
}
})父頁面(組件)監(jiān)聽事件:
<!-- 在父頁面(組件)中 -->
<view>{{ num }}</view>
<!-- 需要在自定義組件標(biāo)簽上通過 bind 方法綁定自定義事件,同時(shí)綁定事件處理函數(shù) -->
<custom05 bind:myevent="getData" />// 在父頁面(組件)中
Page({
data: {
num: ''
},
getData (event) {
// 可以通過事件對(duì)象.detail 獲取子組件傳遞給父組件的數(shù)據(jù)
// console.log(event)
this.setData({
num: event.detail
})
}
})5.2 獲取組件實(shí)例
可在父組件里調(diào)用 this.selectComponent() ,獲取子組件的實(shí)例對(duì)象,就可以直接拿到子組件的任意數(shù)據(jù)和方法。
調(diào)用時(shí)需要傳入一個(gè)匹配選擇器 selector,如:this.selectComponent(".my-component")。
到此這篇關(guān)于微信小程序自定義組件和通信的文章就介紹到這了,更多相關(guān)微信小程序組件和通信內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript htmlencode函數(shù)(ff兼容版) 主要是編輯器中反轉(zhuǎn)html代碼
非常不錯(cuò)的htmlencode 方法,比用正則實(shí)現(xiàn)的更好,而且效率高,推薦使用第一種方法。2009-06-06
JavaScript檢測(cè)瀏覽器是否支持CSS變量代碼實(shí)例
這篇文章主要介紹了JavaScript檢測(cè)瀏覽器是否支持CSS變量代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
JavaScript中創(chuàng)建對(duì)象的7種模式詳解
本文主要介紹了JavaScript中創(chuàng)建對(duì)象的7種模式,具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-02-02
JavaScript編寫實(shí)現(xiàn)飛機(jī)大戰(zhàn)
這篇文章主要為大家詳細(xì)介紹了JavaScript編寫實(shí)現(xiàn)飛機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
基于JS實(shí)現(xiàn)文字轉(zhuǎn)語音即文本朗讀
這篇文章主要為大家詳細(xì)介紹了JavaScript如何利用SpeechSynthesis實(shí)現(xiàn)文字轉(zhuǎn)語音即文本朗讀的功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-10-10

