[猫头虎分享21天微信小程序基础入门教程] 第12天:小程序的自定义组件开发

本文主要是介绍[猫头虎分享21天微信小程序基础入门教程] 第12天:小程序的自定义组件开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[猫头虎分享21天微信小程序基础入门教程] 第12天:小程序的自定义组件开发
请添加图片描述

第12天:小程序的自定义组件开发 🛠️

自我介绍

大家好,我是猫头虎,一名全栈软件工程师。今天我们继续微信小程序的学习,重点了解如何开发自定义组件。自定义组件可以提高代码的复用性和模块化程度,使开发更加高效和灵活。🚀

自定义组件的基础

一、创建自定义组件

1. 创建组件目录和文件

首先,在项目根目录下创建一个 components 文件夹,在其中创建一个自定义组件,例如 my-component

components/my-component/my-component.jsmy-component.jsonmy-component.wxmlmy-component.wxss
2. 定义组件的配置文件

my-component.json 文件中定义组件的基本配置:

{"component": true
}
3. 定义组件的逻辑和样式

my-component.js 文件中定义组件的逻辑:

Component({properties: {title: {type: String,value: 'Default Title'}},data: {// 组件内部数据},methods: {onTap() {this.triggerEvent('customEvent', { message: 'Hello from component' });}}
});

my-component.wxml 文件中定义组件的模板:

<view class="container"><text>{{title}}</text><button bindtap="onTap">Click Me</button>
</view>

my-component.wxss 文件中定义组件的样式:

.container {padding: 20rpx;border: 1px solid #ddd;border-radius: 5rpx;text-align: center;
}

二、使用自定义组件

1. 注册组件

在使用组件的页面中注册组件。在页面的 json 文件中添加如下配置:

{"usingComponents": {"my-component": "/components/my-component/my-component"}
}
2. 使用组件

在页面的 wxml 文件中使用组件:

<view class="page"><my-component title="Custom Title" bind:customEvent="handleCustomEvent"></my-component>
</view>

在页面的 js 文件中处理组件事件:

Page({handleCustomEvent(event) {console.log(event.detail.message); // 输出: Hello from component}
});

组件间通信

一、父组件向子组件传递数据

通过 properties 向子组件传递数据:

Component({properties: {title: {type: String,value: 'Default Title'}}
});

二、子组件向父组件传递事件

通过 triggerEvent 向父组件传递事件:

methods: {onTap() {this.triggerEvent('customEvent', { message: 'Hello from component' });}
}

三、组件之间的数据和事件传递

父组件向子组件传递数据,子组件向父组件传递事件:

<my-component title="Custom Title" bind:customEvent="handleCustomEvent"></my-component>
Page({handleCustomEvent(event) {console.log(event.detail.message); // 输出: Hello from component}
});

组件的生命周期

一、组件的生命周期函数

组件有一系列生命周期函数,可以在不同阶段执行代码:

Component({lifetimes: {attached() {console.log('Component attached to DOM');},ready() {console.log('Component is ready');},detached() {console.log('Component detached from DOM');}}
});

二、页面的生命周期函数

组件也可以监听页面的生命周期函数:

Page({onLoad() {console.log('Page loaded');},onReady() {console.log('Page ready');},onUnload() {console.log('Page unloaded');}
});

小测试 🧪

  • 创建一个自定义组件,并在页面中使用它。
  • 实现父组件向子组件传递数据,子组件向父组件传递事件。

今日学习总结 📚

概念详细内容
自定义组件创建组件目录和文件,定义组件的配置、逻辑和样式
组件间通信父组件向子组件传递数据,子组件向父组件传递事件
组件的生命周期函数组件和页面的生命周期函数

结语

通过今天的学习,你应该掌握了如何在小程序中开发自定义组件,并了解了组件之间的数据和事件传递。这些技术可以帮助你构建更加模块化和高效的小程序。明天我们将探讨小程序的性能优化与最佳实践。如果你有任何疑问,欢迎关注并留言在我的公众号猫头虎技术团队。📩


这篇关于[猫头虎分享21天微信小程序基础入门教程] 第12天:小程序的自定义组件开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/999118

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca