微信小程式 發現之旅(二)—— 自定義組件

来源:https://www.cnblogs.com/wisewrong/archive/2018/06/01/8962635.html
-Advertisement-
Play Games

組件化的項目開發中,組件應當劃分為三個層次:組件、模塊、頁面 微信小程式已經為開發者封裝好了基礎組件,頁面文件(pages)也有了詳細的規定 而模塊就需要自行開發,並且要和頁面文件區分開,這就涉及到自定義組件 一、基本用法 在根目錄下創建一個 components 目錄,用於存放自定義組件 組件也是 ...


組件化的項目開發中,組件應當劃分為三個層次:組件、模塊、頁面

微信小程式已經為開發者封裝好了基礎組件,頁面文件(pages)也有了詳細的規定

而模塊就需要自行開發,並且要和頁面文件區分開,這就涉及到自定義組件

 

 

一、基本用法

在根目錄下創建一個 components 目錄,用於存放自定義組件

組件也是由 json、wxml、wxss、js 四個文件組成

其中 wxml 部分沒有什麼特殊的地方,和頁面的寫法一致

wxss 也是只對組件生效,而且 app.wxss 中的樣式也不會對自定義組件生效

最關鍵的地方在於,需要在 json 中添加配置項:

component 欄位設為 true這樣才能註冊這個自定義組件

 

當需要在頁面中使用自定義組件的時候,在頁面的 json 文件中添加聲明:

{
  "usingComponents": {
    "組件名": "組件路徑"
  }
}

然後就能在頁面的 wxml 中直接使用該組件

 

 

二、參數傳遞  組件與組件之間的參數傳遞比較複雜,留到下一篇博客中細說,這裡只介紹 properties 

小程式的頁面 pages 需要使用 Page() 來註冊,而組件則需要 Component() 構造器

如果組件需要接受一個外部數據,比如一個列表組件的數據源 data,可以這麼配置:

這裡的 properties 類似於 vue 中的 props,表示該對象下的屬性將從外部傳入

properties 可設置 type、value、observer 三個屬性

其中 type 用於指定欄位類型( Number,String,Array,Object,Function)

value 表示欄位的預設值,observer 用於定義該欄位的監聽函數

 

在頁面上調用組件的時候,直接給 data 賦值就好:

PS:開發中應當避免使用 data 為首碼的屬性名(如 data-info),這會被識別為 dataset 中的參數

 

 

三、組件插槽

小程式的組件也可以使用 <slot> 來擴展內容

然後父組件引入這個組件的時候,可以在組件中插入節點,節點內容會渲染到 <slot> 節點的位置

 

組件預設只能有一個 <slot>,如果需要添加多個插槽,首先需要在組件 js 中聲明

Component({
  options: {
    multipleSlots: true // 在組件定義時的選項中啟用多slot支持
  },
  properties: { /* ... */ },
  methods: { /* ... */ }
})

然後需要給 <slot> 命名,以 name 來區分各個插槽

 

 併在引用組件的時候,給節點指定對應的 <slot>

 

 

 

四、Behaviors

在 Vue 的項目中,可以採用 mixin 來引入一些公共方法或參數,小程式的 behaviors 和 mixin 十分相似

每個 behavior 通常是一個單獨的 js 文件,由 Behavior() 構造器創建,和 Components() 組件構造器類似,可以包含一組屬性、數據、生命周期函數和方法

// components/behaviors/wise.js
module.exports = Behavior({
  behaviors: [],  // 可以引用別的 behaviors
  properties: {
    subName: {
      type: String
    }
  },
  data: {
    subInfo: 'so cool you are'
  },
  attached: function () {},
  methods: {
    handleSubmit: function () {
      console.log('submit')
    }
  }
})

使用的時候,在組件中引入,然後聲明該 behaviors

然後就能直接在組件中使用 behaviors 中定義的數據了

 


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

-Advertisement-
Play Games
更多相關文章
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...