微信小程序 | 小程序组件化开发

简介: 微信小程序 | 小程序组件化开发

一、小程序组件化思想

小程序组件化开发

  • 小程序刚推出时是不支持组件化的,也是为人诟病的一个点
  • 从1.6.3开始,便支持自定义组件开发了,也让我们更加方便在程序中使用组件化

e871a502ecbb4006938482a86dd66d49.png

  • 组件化思想的应用:
  • 我们在之后的开发中可以充分利用它
  • 尽可能将页面拆成一个个 小的、可复用的组件
  • 这会让我们的代码更加 方便组织管理,并且拓展性更强

二、自定义组件的过程

创建一个组件

  • 类似于页面,自定义组件由 json wxml wxjj js 四个文件组成
  • 先在根目录下创建一个文件夹;
  • components里存放 自定义的公共组件
  • 常见的一个自定义组件 section-info: 包含对应的四个文件

d9752f45c97041f995b8fe29a603fb63.png

fff49e53d6cd40999e60ad4a1f705981.png

  • 自定义组件步骤
  • 需要在json文件中进行 自定义组件声明(将component字段设置为true 可以讲这一组文件设为自定义组件(当你在文件中设置了这个属性之后,那么它将是一个组件)

68c1108aacec438e92eddcb4c844a810.png

f246d6b87e8c4e9f8efd91328fe6027b.png

  • 在wxml中编写属于自定义组件自己的模板
  • 在wxss中编写属于自己的样式
  • 在js文件中,定义数据或组件内部的相关逻辑代码

9db96facaaa54f7ab13b4898256a2557.png

  • 在哪个组件中想要使用自定义组件,那么就在哪个里面的json文件中进行书写.

使用自定义组件和细节注意事项

  • 自定义组件也是可以引用自定义组件的,引用方法类似于页面引用自定义组件的方式(使用usingComponents 字段)
  • 自定义组件和页面所在项目根目录 名 不能以“wx-”为前缀,否则会报错
  • 如果在app.json的usingComponents声明某个组件,那么所有页面和组件可以直接使用该组件

74e297f45d3d48aeb9a193d763366b24.png

三、组件样式实现细节

组件的样式细节

  • 组件内的样式 对 外部样式 的影响
  • 组件内的class样式 只对组件wxml内的节点生效,对于引用组件的Page页面不生效
  • 组件内不能使用id选择器,属性选择器,标签选择器(会对其他组件进行样式更改)
  • 外部样式 对 组件内样式 的影响
  • 外部使用class的样式,只对外部wxml的class生效,对组件内的无效
  • 外部使用id选择器,属性选择器不会对组件内产生影响
  • 外部使用了 标签选择器 会对组件内产生影响
  • 如何让class可以相互影响?
  • 在Component对象中 可以传入一个 options属性, 其中options属性中有一个 styleIsolation(隔离)属性.
  • stylelsolation有三个取值:
  • Isolated 启用样式隔离,在自定义组件内外,使用class指定的样式将不会相互影响(默认值)
  • Apply-shared 页面wxss样式将影响到自定义组件 但自定义组件中的wxss中指定的样式不影响页面
  • Shared 页面wxss样式将影响到自定义组件,自定义组件 wxss 中指定的样式也会影响页面和其他设置

e0e9dc84916a49ad8c73f46bf6a517f3.png

四、组件使用过程通信

组件的通信

很多情况下,组件内展示的内容(数据、样式、标签),并不是在组件内写死的,而且可以由使用者来决定.

d282e1017a5943fc989037713136f46d.png

向组件传递数据 - properties

  • 给组件传递数据:
  • 大部分情况下,组件只负责布局和样式,内容由使用组件的对象 决定的
  • 我们经常需要从外部传递数据给我们的组件,让我们的组件来进行展示
  • 如何传递? => 使用 properties属性
  • 支持的类型:
  • String Number Boolean
  • Object Array null(不限制类型)
  • 默认值:
  • 通过value来设置

ea4e9bd9d7734ea9a22f3c048a1d9e67.png

9ccdf8f387fa4de4941ab26229bf1e36.png

向组件传递样式 -  externalClasses(较少使用)

  • 给组件传递样式:
  • 我们不希望将样式写在组件内固定不变,而是通过外部来决定样式
  • 这时,我们可以使用externalClasses 属性:
  • 1.在Component对象中,先定义externalClasses属性

fd96795c9a0d45d8ae8b638fe1921bca.png

  • 2.在组件内的wxml中使用externalClasses属性中的class

b5603ea3d2004dce8136ac22bedb3a4e.png

  • 3.在页面中传入对应的class,并且给这个class设置样式


ed9508c3d4b34284b3812b0d05e55d93.png    d07abce1c5d643319a76d9812e0e755d.png

组件向外传递事件 – 自定义事件

有时候是自定义组件内部发生了事件,需要告知使用者,这个时候可以使用自定义事件:

53d761e763c445738beec487159f69fc.png

页面直接调用组件方法(使用的较少)

  • 可以在父组件里调用 this.selectComponent,获取子组件的实例对象
  • 调用时需要传入一个匹配选择器 selector,如:this.selectComponent(".my-component")。

e72fb1f2bceb4ad69b274a675c9453e5.png

48d694b931f84a96be6432ce3078d327.png

9a0e9716803b4ada9cca33f320b1661f.png

五、组件插槽定义使用

什么是插槽?

  • 组件的插槽
  • 为了让我们封装的组件更加具有拓展性
  • 让使用者可以决定组件内部的一些内容到底展示什么?


单个插槽的使用

  • 除了内容和样式可能由外界决定之外,也可能外界想决定显示的方式
  • 如:我们有一个组件定义了头部和尾部,但是中间的内容可能是一段文字,可能是图片,等等...
  • 在不确定外界想插入什么其他组件的前提下,我们可以在组件内预留插槽:

719b0949faab4fc6af885bcb85e1892a.png     55127d49c5f2460287d5a313f4523724.png

这里有一个小问题,如图所示, 小程序中 插槽是不能设置默认值的 那么我们怎么去解决呢?

使用 css中的 :empty

bcc3033413614a72a85b736ffd399cf4.png

JavaScript
// 代码展示
//   插槽代码
<view class="my-slot">
  <view class="header">Header</view>
  <view class="content">
    <!-- <view>哈哈哈哈</view> -->
    <!-- 预留插槽 -->
    <!-- 在小程序中,插槽是不支持默认值的 -->
    <slot>哈哈哈哈</slot>
  </view>
  <!-- 我如果想要我没有写插槽 也有一个默认值怎么办呢? 自己动手  我得让我这个 哈哈哈 在有插入东西时不显示
  没有插入东西的时候 显示 css中实现 -->
  <view class="default">哈哈哈哈</view>
  <view class="footer">Footer</view>
</view>
//  index.wxml中代码
<!-- 1.单个插槽的使用 -->
<my-slot>
  <button>我是按钮</button>
</my-slot>
<my-slot>
  <!-- 插入图片 -->
  <image src="/assets/tabbar/home.png" mode="widthFix"></image>
</my-slot>
<my-slot></my-slot>
<my-slot></my-slot>
// css中代码
.default {
  display: none;
}
/* 可以使用兄弟选择器 */
/* :empty 表示 当前元素内容为空的 */
.content:empty + .default {
  display: block;
 } 

多个插槽的使用

  • 有时候为了让组件更加的灵活,我们需要定义多个插槽:

0e99b0b50cb448d0abda94cc67a6ad61.png    0f1054df059347e4bea879984d0d9415.png    d902e8f0a0c3436780978b72945d6930.png

behaviors

  • behaviors 是用于组件间代码共享的特性,类似于一些编程语言中的  mixins
  • 每个 behavior 可以包含一组属性、数据、生命周期函数和方法
  • 组件引用它时,它的属性、数据和方法会被合并到组件中,生命周期函数也会在对应时机被调用
  • 每个组件可以引用多个 behavior behavior 也可以引用其它 behavior

6d3cac59cf954554b2444eddf6ff20e2.png    508a5e2c251a44b5aa2b0087ca159a5f.png

组件的生命周期

  • 组件的生命周期,值 组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被触发.
  • 最重要的生命周期是 created attached detached 包含一个组件实例生命周期流程的最主要时间点
  • 小程序基础库版本 2.2.3 起,组件的的生命周期也可以在 lifetimes 字段内进行声明(这是推荐的方式,其优先级最高)

e2c143a8436a486b9689d1c51ca4dc34.png

3571fc293b9340a4932cb1f67c2f4acd.png

组件所在页面的生命周期

  • 有一些特殊的生命周期,它们并非与组件有很强的关联,但有时组件需要获知,以便组件内部处理
  • 样的生命周期称为“组件所在页面的生命周期”,在 pageLifetimes 定义段中定义
  • 可用的生命周期包括:

70a0342126b04321a1b58ce466c011ce.png

734ea26d494a4f8aa6857977f1c57734.png

六、Component构造器

7e4e499e67614fb99989df67f5d85133.png

相关文章
|
2月前
|
人工智能 小程序 前端开发
一个小程序轻量AR体感游戏,开发实现解决方案
针对青少年运动兴趣不足问题,AR体感游戏凭借沉浸式互动体验脱颖而出。结合小程序“AI运动识别”插件与WebGL渲染技术,可实现无需外设的轻量化AR健身游戏,如跳糕、切水果等,兼具趣味性与锻炼效果,适用于儿童健身及职工团建,即开即玩,低门槛高参与。
|
2月前
|
移动开发 小程序 前端开发
小程序开发平台有哪些?哪个好
小程序的开发方式丰富多元,开发团队可根据自身的技术背景、项目具体需求以及资源状况,灵活挑选最为适宜的开发路径。以下将详细介绍几种主流的小程序开发方式。
298 3
|
2月前
|
运维 小程序 数据可视化
小程序开发平台有哪些?SaaS小程序制作平台哪个好
小程序开发模式详解:自主开发、SaaS小程序制作平台与外包全对比 选择合适的小程序开发模式,是项目成功的基石。这三种模式在成本、周期、控制力和灵活性上各有千秋,适用于不同阶段和不同类型的企业。下面我们将逐一深入剖析。
268 7
|
2月前
|
移动开发 小程序 前端开发
小程序快速开发平台有哪些?
小程序开发并非“一刀切”,需结合技术储备、资金预算、时间规划及功能需求等多维度因素综合考量。以下为您详细拆解五种主流开发方案及其适用场景,助您精准匹配开发路径。
198 3
|
2月前
|
移动开发 小程序 前端开发
小程序开发平台有哪些?小程序开发制作软件推荐
小程序开发方案全解析:5种主流方式与选择指南 小程序开发需根据技术能力、预算、时间及功能需求综合决策。以下为5种主流开发方案及适用场景分析:
453 0
|
3月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
3月前
|
缓存 小程序 前端开发
商城/点餐/家政类小程序源码合集_微信抖音小程序源码开发从入门到精通实战
本文系统讲解如何利用现有源码快速开发商城、点餐、家政类微信/抖音小程序,涵盖环境搭建、核心功能实现、多平台部署与优化,提供完整技术方案。实战导向,助力开发者高效入门与落地。
|
3月前
|
存储 小程序 Java
热门小程序源码合集:微信抖音小程序源码支持PHP/Java/uni-app完整项目实践指南
小程序已成为企业获客与开发者创业的重要载体。本文详解PHP、Java、uni-app三大技术栈在电商、工具、服务类小程序中的源码应用,提供从开发到部署的全流程指南,并分享选型避坑与商业化落地策略,助力开发者高效构建稳定可扩展项目。