麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 課堂 > 小程序 > 正文

微信小程序之自定義組件的實現(xiàn)代碼(附源碼)

2020-03-21 16:12:41
字體:
供稿:網(wǎng)友

最近在項目開發(fā)中,遇到好多雷同的頁面樣式,就想著可以將常用的功能模塊封裝成組件,方便在項目中使用和修改,下面就參照微信小程序的文檔分步驟寫一個微信小程序的組件。

附上效果圖:

微信小程序,代碼,源碼

step1:創(chuàng)建文件并申明

與創(chuàng)建微信小程序的頁面一樣,一個自定義組件也需要json,wxml,wxss,js四個文件。

在項目根目錄中創(chuàng)建文件夾,取名為:component,在該目錄下繼續(xù)創(chuàng)建文件夾successModal。

可以在開發(fā)工具中右鍵創(chuàng)建,選擇component,默認自動會創(chuàng)建四個文件。如圖:

微信小程序,代碼,源碼

在successModal.json文件中進行自定義組件聲明,如:

在開發(fā)工具中右鍵新建選擇component,默認自動會創(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:編寫樣式文件

/* 這里的樣式只應用于這個自定義組件 *//*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è)務邏輯

在自定義組件的 js 文件中,需要使用 Component() 來注冊組件,組件的屬性值和內(nèi)部數(shù)據(jù)將被用于組件 wxml 的渲染,其中,屬性值是可由組件外部傳入的。

//successModal.jsComponent({ /** * 組件的屬性列表 */ properties: { //這里定義了modalHidden屬性,屬性值可以在組件使用時指定.寫法為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文件中進行引用申明,然后需要提供每個自定義組件的標簽名和對應的自定義組件文件路徑。

//index.json{ "usingComponents": { "modal-success": "../../component/successModal/successModal" //在這里寫上頁面中自定義的標簽名和自定義組件的文件路徑 }, "navigationBarTitleText": "首頁"}

其次,在頁面的wxml中使用自定義組件:在頁面的 wxml 中就可以像使用基礎組件一樣使用自定義組件。節(jié)點名即自定義組件的標簽名,節(jié)點屬性即傳遞給組件的屬性值。

<!--index.wxml--><view class="container"> <view class="demoBtn" bindtap="bindViewTap"> <text>點擊</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

注意點:

  • 對于基礎庫的1.5.x版本, 1.5.7 也有部分自定義組件支持。
  • 因為WXML節(jié)點標簽名只能是小寫字母、中劃線和下劃線的組合,所以自定義組件的標簽名也只能包含這些字符。
  • 自定義組件也是可以引用自定義組件的,引用方法類似于頁面引用自定義組件的方式(使用 usingComponents 字段)。
  • 自定義組件和使用自定義組件的頁面所在項目根目錄名不能以“wx-”為前綴,否則會報錯。
  • 舊版本的基礎庫不支持自定義組件,此時,引用自定義組件的節(jié)點會變?yōu)槟J的空節(jié)點。

總結(jié)

以上所述是小編給大家介紹的微信小程序之自定義組件的實現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網(wǎng)網(wǎng)站的支持!


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产污污视频 | 亚洲欧美成aⅴ人在线观看 免费看欧美黑人毛片 | 色的综合 | 国产一区免费视频 | 欧美一级在线看 | 欧美性受xxx黑人xyx性爽 | 欧美成人免费电影 | 最新亚洲视频 | 北原夏美av | 久草在线资源观看 | 欧美日韩国产一区二区三区在线观看 | aa久久| 天天色宗合 | 日本黄色免费观看视频 | 欧美一级在线免费 | 国产精品久久久久久久久久 | 免费a级网站 | 国产精品久久久久久238 | 国产日本在线播放 | 国产精品久久久久久久久久10秀 | xxxⅹ96日本护士hd | 在线看免费的a | 欧美日韩在线播放 | 成人综合一区二区 | 日韩一级免费毛片 | 精品无吗乱吗av国产爱色 | 蜜桃91丨九色丨蝌蚪91桃色 | 国产成人精品一区二区三区电影 | 亚洲欧美一区二区三区在线观看 | 97伦理| 中文字幕精品久久 | 依依成人精品视频 | 久久精品视频日本 | 羞羞草视频| 日韩精品中文字幕一区二区 | 黄网站在线免费看 | 国产精品影视 | 精国产品一区二区三区四季综 | 小情侣嗯啊哦视频www | h视频免费在线观看 | 精品在线观看一区二区三区 |