小程式:自定義組件的實現方法及自定義組件與頁面間的數據傳遞

来源:https://www.cnblogs.com/jervy/archive/2018/10/09/9761191.html
-Advertisement-
Play Games

首先我們在pages文件夾下創建components目錄用於存放自定義組件。如圖所示,以我創建的dialog組件為例,自定義組件的格式與頁面一樣,分為4個文件。 圖1 圖2 如上圖2所示,假如index頁面有一個按鈕觸發點擊事件後彈出dialog,並且當點擊某個部門時,將dialog關閉,並將部門名 ...


首先我們在pages文件夾下創建components目錄用於存放自定義組件。如圖所示,以我創建的dialog組件為例,自定義組件的格式與頁面一樣,分為4個文件。

  圖1                        圖2

如上圖2所示,假如index頁面有一個按鈕觸發點擊事件後彈出dialog,並且當點擊某個部門時,將dialog關閉,並將部門名稱與紅色標題同步。

一、首先把dialog組件的樣式寫好,併在index頁面相應的位置引用。以下就是代碼啦(分別為:wxml、wxss、js、json)

  <view class='wx_dialog_container' hidden="{{!isShow}}">
    <view class='wx-mask' bindtap='close'></view>
    <view class='wx-dialog'>
      <text class='li' bindtap='groupClick' wx:for="{{items}}" data-index='{{index}}' wx:for-item="item">{{item.department}}</text> 
    </view>
  </view>
.wx_dialog_container{
  width: 100%;
  height: 100%;
  z-index: 999;
}
.wx-mask{
  position: fixed;
    z-index: 1000;
    top: 0;
    right: 0;
    left: 35%;
    bottom: 0;
    background: rgba(0, 0, 0, 0.3);
}
.wx-dialog{
    position: fixed;
    min-width: 528rpx;
    height: 100%;
    left: 0;
    top:314px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background-color: #FFFFFF;
    text-align:left;
}
.wx-dialog .li{
    display: block;
    font-size: 18px;
    margin-top:28px;
    margin-left:154px;
}
Component({
  properties: {
    
  },
  data: {
    isShow: false,
    animationData: {},
    color:"#000",
    items:[
      { department: '研發部'},
      { department: '設計部' },
      { department: '人事部'},
      { department: '銷售部' },
      { department: '市場運營部' },
    ]
  },

  methods: {
    show: function () {
      this.setData({
        isShow: true
      });
    },
  
    close: function () {
      this.setData({
        isShow: false
      })
    },

  // 自定義組件與頁面之間的數據通信
    groupClick: function (e){
      var group = this.data.items[e.target.dataset.index]
      console.log(group)
      // 使用 triggerEvent 方法觸發自定義組件事件,指定事件名、detail對象和事件選項
      this.triggerEvent('okEvent', { group}, {})
 
      
      this.setData({
        isShow: false

      })
    },
 
  },
})
{
  "component": true
}

最後一步別忘了在你相應的頁面中引用它,註意:自定義組件名稱要和components目錄下的一致。如下圖我在index.wxml中使用它

二、組件與頁面怎麼數據通信呢?

  • 首先要知道你點擊的是列表中的哪個部門,所有要為列表元素添加一個 groupClick事件 列印出事件對象 e ,我們發現我們要的數據在e.target.dataset.index里
  • 已經得到數據對象了,下一步就是想辦法把它傳遞給 index頁面更新數據。在當前頁面想要獲取組件中的某一狀態,需要使用到this.triggerEvent(' ',{},{}),第一個參數是自定義事件名稱,所以還要在組件身上綁定個自定義事件,第二個對象就是你要傳遞的數據,第三個一般不用(代碼參見標黃部分)
  • 最後就是在頁面的index.js中定義這個事件來接收dialog的數據,並列印出 e 找到數據更新數據。(如下代碼)
  // 接受triggerEvent 方法觸發的自定義組件事件來更新同步數據
  okEvent: function (e) {
    console.log(e)
    this.setData({
      groupName: e.detail.group.department
    })
    
  },

 

三、最後一個小知識

如果想在 index.js邏輯中引用dialog.js 中methods里定義好的方法,需要在index.js 中添加如下代碼

 onReady: function () {
    this.dialog = this.selectComponent('#dialog');
  },

比如:我把show、close 方法定義在了組件中的methods 里,要在index頁面中觸發某個時間讓dialog展示,只需在index.js 中這麼寫即可。

            

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ListView現在已經很少被使用,但還是在這裡列出來說一下,有時候我們僅僅需要改變listView的某個Item,如果調用adapter的notifyDataSetChanged()方法效率不高,並且可能會出現內容閃動,那麼我們怎麼刷新某一個特定的item呢? 在這裡我們以刷新第一個item為例, ...
  • 本文主要介紹Flutter佈局中的LimitedBox、Offstage、OverflowBox、SizedBox四種控制項,詳細介紹了其佈局行為以及使用場景,並對源碼進行了分析。 ...
  • 慶祝 2018 國慶,製作了一個 的種子下載器。爬取頁面,根據頁面的鏈接,破解另外一個網站,下載種子文件,同時使用 模塊提高爬蟲的併發量。項目比較簡單,爬取頁面沒有使用任何爬蟲框架。 的安裝請看我的另外一篇文章, "Node.js 的多版本安裝" 。 項目初始化 新建一個文件夾 ,在該文件夾下打開命 ...
  • 今天面試的時候被問到一個問題,是關於 JS 非同步的。當時我腦海中閃過了一個單線程的概念,但卻沒有把真正的原理闡述清楚。所以回來特意重新回顧了前面單線程和非同步相關的一些知識點。 雖然之前學習的時候也接觸了單線程模型相關的東西,但當時理解得並不是很清楚和明白。所以這道面試題也沒有給出一語中的的答案。重新 ...
  • javascript是面向對象的語言,Function也是一種對象,有自己的屬性和方法。call和apply就是js函數自帶方法,掛在Fucntion.prototype上。 一般調用某函數時,直接“函數名(參數)”的寫法即可,函數內部的this指向函數的調用者。 call和apply的作用是給函數 ...
  • 可以根據屏幕尺寸提供完全不同的圖片,為那些沒有必要下載全尺寸大圖的設備節省帶寬。 ...
  • 這裡附一篇自己的簡短理解 get相對於post更不安全,雖然都可以加密 get的參數會顯示在瀏覽器地址欄中,而post的參數不會顯示在瀏覽器地址欄中; 使用post提交的頁面在點擊【刷新】按鈕的時候瀏覽器一般會提示“是否重新提交”,而get則不會; 用get的頁面可以被搜索引擎抓取,而用post的則 ...
  • .not() 遍歷方法 從匹配元素集合中移除元素 :not() 選擇器 選取除了指定元素以外的所有元素。 獲取ul中除 id="unwanted" 的其他所有 li ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...