溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在解微信小程序中通過(guò)自定義組件實(shí)現(xiàn)數(shù)據(jù)交互

發(fā)布時(shí)間:2021-06-04 17:44:36 來(lái)源:億速云 閱讀:362 作者:Leah 欄目:web開(kāi)發(fā)

本篇文章給大家分享的是有關(guān)怎么在解微信小程序中通過(guò)自定義組件實(shí)現(xiàn)數(shù)據(jù)交互,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

step1:創(chuàng)建文件夾以及文件

首先創(chuàng)建一個(gè)components(名字可自?。┪募A,用于放置所有自定義的組件,

里面可以用右鍵自動(dòng)創(chuàng)建的方式,新建一個(gè)Component組件,例如:

怎么在解微信小程序中通過(guò)自定義組件實(shí)現(xiàn)數(shù)據(jù)交互

創(chuàng)建之后的目錄結(jié)構(gòu)為:

怎么在解微信小程序中通過(guò)自定義組件實(shí)現(xiàn)數(shù)據(jù)交互

其中callphone是我們本次要實(shí)現(xiàn)的撥打電話組件。

step2:組件的基本搭建

在callphone.wxml中:添加組件結(jié)構(gòu):

<view class="call" bindtap="callPhone">
 <view class="phone">{{phone}}</view>
 <view>了解最新信息,免費(fèi)咨詢</view>
 <view class="callIcon"></view>
</view>

在callphone.wxss中:添加組件樣式:

.call {
 display: block;
 padding: 18rpx 30rpx;
 width: 100%;
 color: #999;
 font-size: 24rpx;
 box-sizing: border-box;
 background: #ecf9e8;
 position: relative;
 border-radius: 10rpx;
}
.call .phone {
 color: #333;
 font-size: 40rpx;
}
.call .callIcon {
 width: 77rpx;
 height: 77rpx;
 position: absolute;
 top: 50%;
 margin-top: -38rpx;
 right: 30rpx;
 background-size: cover;
 background-image: url();
}

在callphone.js中:添加組件邏輯:

Component({
 /**
  * 組件的屬性列表
  */
 properties: {

 },
 /**
  * 組件的初始數(shù)據(jù)
  */
 data: {
  phone: '400-010-9797'
 },
 /**
  * 組件的方法列表
  */
 methods: {
  callPhone() {
   wx.makePhoneCall({
    phoneNumber: this.data.phone
   })
  }
 }
})

step3:使用組件

我們要在index.wxml中使用該組件的話,要在index.json中進(jìn)行聲明:(其中call-phone是組件的名稱(chēng),可以自?。?br/>

{
 "usingComponents": {
  "call-phone": "/components/CallPhone/callphone"
 }
}

在index.wxml中引用組件:

<call-phone></call-phone>

完成以上幾個(gè)步驟,一個(gè)簡(jiǎn)單的小程序自定義組件就完成了,運(yùn)行結(jié)果如下:

怎么在解微信小程序中通過(guò)自定義組件實(shí)現(xiàn)數(shù)據(jù)交互

Page與Component數(shù)據(jù)交互

上面的例子中可以看到,電話號(hào)碼是在組件中的data中設(shè)置的,也就是每個(gè)頁(yè)面都是固定寫(xiě)死的;但是如果要實(shí)現(xiàn)每個(gè)界面的號(hào)碼不一樣的話,此時(shí)就涉及到page往組件傳值的問(wèn)題,可以這么修改:

1、page > component

方法1:page在引用組件時(shí)能通過(guò)屬性值設(shè)置,callphone.js在properties獲取:

<!--index.wxml-->
<call-phone phone="400-010-9797"></call-phone>
// components/CallPhone/callphone.js
Component({
 properties: {
  phone: String //簡(jiǎn)寫(xiě)
  /* 
  phone: {
   type: String, //類(lèi)型,目前接受的類(lèi)型包括:String, Number, Boolean, Object, Array, null(表示任意類(lèi)型)
   value: '', //初始值
   observer: function(newVal, oldVal) {}
  }
  */
 },
 attached: function() {
  console.log("this.properties.phone:" + this.properties.phone); //控制臺(tái)打印:"400-010-9797"
 },
 //...
})

方法2:page在引用組件時(shí)通data-xxx設(shè)置,callphone.js在this.dataset獲取:

<!--index.wxml-->
<call-phone data-tel="400-010-9797" ></call-phone>
// components/CallPhone/callphone.js
Component({
 attached: function() {
  console.log("this.dataset.tel:" + this.dataset.tel); //控制臺(tái)打印:"400-010-9797"
  // 設(shè)置properties值用setData()
  this.setData({
   phone: this.dataset.tel
  });
 },
 //...
})

2、component > page

組件中的變量要傳到page頁(yè)面,可以通過(guò)事件觸發(fā)this.triggerEvent()來(lái)實(shí)行:

// components/CallPhone/callphone.js
Component({
 methods: {
  callPhone() {
   var myEventDetail = {
    msg: '來(lái)自component的信息',
    tel: '400-010-9797'
   } // detail對(duì)象,提供給事件監(jiān)聽(tīng)函數(shù)
   var myEventOption = {} // 觸發(fā)事件的選項(xiàng)
   this.triggerEvent('myevent', myEventDetail, myEventOption)
  }
 }
})
<!--index.wxml-->
<!--"bindmyevent"屬性與上面"myevent"對(duì)應(yīng),當(dāng)自定義組件觸發(fā)"myevent"事件時(shí),調(diào)用"call"方法 -->
<call-phone bindmyevent="call"></call-phone>
//index.js
Page({
 call: function(e) {
  console.log(e.detail.msg);//控制臺(tái)打印:"來(lái)自component的信息"
  wx.makePhoneCall({
   phoneNumber: e.detail.tel
  })
 }
})

以上就是怎么在解微信小程序中通過(guò)自定義組件實(shí)現(xiàn)數(shù)據(jù)交互,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI