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

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

 更新時間:2018年08月02日 11:02:39   作者:yanyw  
最近在項目開發(fā)中,遇到好多雷同的頁面樣式,就想著可以將常用的功能模塊封裝成組件,方便在項目中使用和修改。這篇文章主要介紹了微信小程序之自定義組件的實現代碼(附源碼),需要的朋友可以參考下

最近在項目開發(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:編寫組件模板代碼

<!-- 這是自定義組件的內部WXML結構 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() 來注冊組件,組件的屬性值和內部數據將被用于組件 wxml 的渲染,其中,屬性值是可由組件外部傳入的。

//successModal.js
Component({
 /**
 * 組件的屬性列表
 */
 properties: {
 //這里定義了modalHidden屬性,屬性值可以在組件使用時指定.寫法為modal-hidden 
 modalHidden: {
  type: Boolean,
  value: true
 },
 modalIcon: {
  type: String,
  value: ' ',
 },
 modalTitle: {
  type: String,
  value: ' ',
 },
 modalDesc: {
  type: String,
  value: ' ',
 }
 },

 /**
 * 組件的初始數據
 */
 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>
 <!-- 調用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é)點。

總結

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

相關文章

  • 詳解使用JWT實現單點登錄(完全跨域方案)

    詳解使用JWT實現單點登錄(完全跨域方案)

    這篇文章主要介紹了詳解使用JWT實現單點登錄(完全跨域方案),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • JSONP跨域的原理解析及其實現介紹

    JSONP跨域的原理解析及其實現介紹

    JSONP跨域GET請求是一個常用的解決方案,下面我們來看一下JSONP跨域是如何實現的,并且探討下JSONP跨域的原理
    2014-03-03
  • JS實現選項卡插件的兩種寫法(jQuery和class)

    JS實現選項卡插件的兩種寫法(jQuery和class)

    這篇文章主要為大家詳細介紹了JS實現選項卡插件的兩種寫法:jQuery和class,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • JS實現導出Excel的五種方法詳解【附源碼下載】

    JS實現導出Excel的五種方法詳解【附源碼下載】

    這篇文章主要介紹了JS實現導出Excel的五種方法,結合實例形式較為詳細的分析了基于table表格導出Excel文件的相關操作技巧,并附源碼供讀者下載參考,需要的朋友可以參考下
    2018-03-03
  • 如何在JavaScript中使用map()迭代數組詳細步驟

    如何在JavaScript中使用map()迭代數組詳細步驟

    在JavaScript中循環(huán)迭代數組的方法有很多種,下面這篇文章主要給大家介紹了關于如何在JavaScript中使用map()迭代數組的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • JavaScript 實現輪播圖特效的示例

    JavaScript 實現輪播圖特效的示例

    這篇文章主要介紹了JavaScript 實現輪播圖特效,幫助大家更好的制作網頁,完成需求,感興趣的朋友可以了解下
    2020-11-11
  • 防止文件緩存的js代碼

    防止文件緩存的js代碼

    原理其實就是通過在固定地址后面,加上一個不同值的日期數值,以達到地址不重復的目的,讓瀏覽器每次都實時加載,不從緩存中讀取文件
    2013-01-01
  • JS之小練習代碼

    JS之小練習代碼

    初學者不建議看,這些都是用類實現的代碼,高手推薦學習
    2008-10-10
  • 基于JavaScript怎么實現讓歌詞滾動播放

    基于JavaScript怎么實現讓歌詞滾動播放

    各種音樂播放器上都有一個自動滾動播放歌詞的功能,當前滾動到的歌詞會高亮居中顯示,即使歌詞被換行也能正常居中,那么這個功能基于JavaScript怎么實現讓歌詞滾動播放呢?感興趣的朋友一起看看吧
    2015-11-11
  • table insertRow、deleteRow定義和用法總結

    table insertRow、deleteRow定義和用法總結

    這篇文章主要對table insertRow、deleteRow定義和用法做下總結,需要的朋友可以參考下
    2014-05-05

最新評論