微信小程序之自定義組件的實(shí)現(xiàn)代碼(附源碼)
最近在項(xiàng)目開發(fā)中,遇到好多雷同的頁面樣式,就想著可以將常用的功能模塊封裝成組件,方便在項(xiàng)目中使用和修改,下面就參照微信小程序的文檔分步驟寫一個(gè)微信小程序的組件。
附上效果圖:
step1:創(chuàng)建文件并申明
與創(chuàng)建微信小程序的頁面一樣,一個(gè)自定義組件也需要json,wxml,wxss,js四個(gè)文件。
在項(xiàng)目根目錄中創(chuàng)建文件夾,取名為:component,在該目錄下繼續(xù)創(chuàng)建文件夾successModal。
可以在開發(fā)工具中右鍵創(chuàng)建,選擇component,默認(rèn)自動(dòng)會(huì)創(chuàng)建四個(gè)文件。如圖:
在successModal.json文件中進(jìn)行自定義組件聲明,如:
在開發(fā)工具中右鍵新建選擇component,默認(rèn)自動(dòng)會(huì)創(chuàng)建。
{ "component": true, "usingComponents": {} }
step2:編寫組件模板代碼
<!-- 這是自定義組件的內(nèi)部WXML結(jié)構(gòu) success.wxml--> <view class='modal-section' wx:if="{{modalHidden}}"> <view class='modal-opaci' bindtap='modal_click_Hidden'></view> <view class='modal-cont'> <icon type='{{modalIcon}}' size='70'></icon> <text class='modal-titleTxt {{modalIcon}}'>{{modalTitle}}</text> <text class='success-msg'>{{modalDesc}}</text> </view> </view>
step3:編寫樣式文件
/* 這里的樣式只應(yīng)用于這個(gè)自定義組件 */ /*successModal.wxss*/ .modal-opaci { position: absolute; left: 0; top: 0; z-index: 100; height: 100%; width: 100%; background: black; opacity: 0.4; filter: alpha(opacity=40); } .modal-cont { position: fixed; top: 30%; left: 8.5%; z-index: 999; border-radius: 20rpx; padding: 40rpx 150rpx; background-color: #fff; text-align: center; } .modal-cont text { line-height: 90rpx; display: block; } .success { color: #09bb07; } .modal-titleTxt { font-size: 50rpx; font-weight: 700; } .warn { color: #f76260; }
step4:編寫業(yè)務(wù)邏輯
在自定義組件的 js 文件中,需要使用 Component() 來注冊(cè)組件,組件的屬性值和內(nèi)部數(shù)據(jù)將被用于組件 wxml 的渲染,其中,屬性值是可由組件外部傳入的。
//successModal.js Component({ /** * 組件的屬性列表 */ properties: { //這里定義了modalHidden屬性,屬性值可以在組件使用時(shí)指定.寫法為modal-hidden modalHidden: { type: Boolean, value: true }, modalIcon: { type: String, value: ' ', }, modalTitle: { type: String, value: ' ', }, modalDesc: { type: String, value: ' ', } }, /** * 組件的初始數(shù)據(jù) */ data: { }, /** * 組件的方法列表 */ methods: { // 這里是自定義方法 modal_click_Hidden: function () { this.setData({ modalHidden: false, }) }, } })
step5:使用自定義組件
首先在需要使用的json文件中進(jìn)行引用申明,然后需要提供每個(gè)自定義組件的標(biāo)簽名和對(duì)應(yīng)的自定義組件文件路徑。
//index.json { "usingComponents": { "modal-success": "../../component/successModal/successModal" //在這里寫上頁面中自定義的標(biāo)簽名和自定義組件的文件路徑 }, "navigationBarTitleText": "首頁" }
其次,在頁面的wxml中使用自定義組件:在頁面的 wxml 中就可以像使用基礎(chǔ)組件一樣使用自定義組件。節(jié)點(diǎn)名即自定義組件的標(biāo)簽名,節(jié)點(diǎn)屬性即傳遞給組件的屬性值。
<!--index.wxml--> <view class="container"> <view class="demoBtn" bindtap="bindViewTap"> <text>點(diǎn)擊</text> </view> <!-- 調(diào)用modal組件 --> <modal-success modal-hidden="{{is_modal_Hidden}}" modal-icon="{{is_modal_icon}}" modal-title="{{is_modal_title}}" modal-desc="{{is_modal_desc}}" /> </view>
以上就是小程序自定義組件的demo,歡迎start。
github地址:https://github.com/ywyan/wx-component
注意點(diǎn):
- 對(duì)于基礎(chǔ)庫的1.5.x版本, 1.5.7 也有部分自定義組件支持。
- 因?yàn)閃XML節(jié)點(diǎn)標(biāo)簽名只能是小寫字母、中劃線和下劃線的組合,所以自定義組件的標(biāo)簽名也只能包含這些字符。
- 自定義組件也是可以引用自定義組件的,引用方法類似于頁面引用自定義組件的方式(使用 usingComponents 字段)。
- 自定義組件和使用自定義組件的頁面所在項(xiàng)目根目錄名不能以“wx-”為前綴,否則會(huì)報(bào)錯(cuò)。
- 舊版本的基礎(chǔ)庫不支持自定義組件,此時(shí),引用自定義組件的節(jié)點(diǎn)會(huì)變?yōu)槟J(rèn)的空節(jié)點(diǎn)。
總結(jié)
以上所述是小編給大家介紹的微信小程序之自定義組件的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
詳解使用JWT實(shí)現(xiàn)單點(diǎn)登錄(完全跨域方案)
這篇文章主要介紹了詳解使用JWT實(shí)現(xiàn)單點(diǎn)登錄(完全跨域方案),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08JS實(shí)現(xiàn)選項(xiàng)卡插件的兩種寫法(jQuery和class)
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)選項(xiàng)卡插件的兩種寫法:jQuery和class,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12JS實(shí)現(xiàn)導(dǎo)出Excel的五種方法詳解【附源碼下載】
這篇文章主要介紹了JS實(shí)現(xiàn)導(dǎo)出Excel的五種方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了基于table表格導(dǎo)出Excel文件的相關(guān)操作技巧,并附源碼供讀者下載參考,需要的朋友可以參考下2018-03-03如何在JavaScript中使用map()迭代數(shù)組詳細(xì)步驟
在JavaScript中循環(huán)迭代數(shù)組的方法有很多種,下面這篇文章主要給大家介紹了關(guān)于如何在JavaScript中使用map()迭代數(shù)組的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02JavaScript 實(shí)現(xiàn)輪播圖特效的示例
這篇文章主要介紹了JavaScript 實(shí)現(xiàn)輪播圖特效,幫助大家更好的制作網(wǎng)頁,完成需求,感興趣的朋友可以了解下2020-11-11基于JavaScript怎么實(shí)現(xiàn)讓歌詞滾動(dòng)播放
各種音樂播放器上都有一個(gè)自動(dòng)滾動(dòng)播放歌詞的功能,當(dāng)前滾動(dòng)到的歌詞會(huì)高亮居中顯示,即使歌詞被換行也能正常居中,那么這個(gè)功能基于JavaScript怎么實(shí)現(xiàn)讓歌詞滾動(dòng)播放呢?感興趣的朋友一起看看吧2015-11-11table insertRow、deleteRow定義和用法總結(jié)
這篇文章主要對(duì)table insertRow、deleteRow定義和用法做下總結(jié),需要的朋友可以參考下2014-05-05