自定义组件-抽象节点

抽象节点

官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework/custom-component/generics.html

有时,自定义组件模版的一些节点,其对应的自定义组件不是由自定义组件本身确定,而是由自定义组件的调用者确定的,

这时就可以把这个节点声明为抽象节点

  • 这个特性自小程序基础库版本 1.9.6 开始支持。

代码实操

//文件结构
-components
 -generics
		-custom-checkbox.js
		-...
		-custom-radio.js
		-...
		-default.js
    -...
    -selected-group.js
		-...
-pages
	-index
		-index.js

调用关系图

在这里插入图片描述

  • custom-checkbox.wxml
<checkbox disabled="{{ disabled }}" checked="{{ selected }}"></checkbox>
  • custom-checkbox.js
Component({
  properties: {
        disabled:Boolean,
        selected:Boolean
    },
})
  • custom-radio.wxml
<radio disabled="{{disabled}}" checked="{{ selected }}"></radio>
  • custom-radio.js
Component({
  properties: {
        disabled:Boolean,
        selected:Boolean
    },
})
  • selected-group.wxml
<!--抽象节点 -->
<view wx:for="{{labels}}" wx:key="this">
    <label bindtap="itemtap" data-index="{{index}}">
        <!-- 写抽象节点 -->
        <selectable disable="{{false}}" selected="{{selected[index]}}"/>
        {{item}}
    </label>
</view>
  • selected-group.js
Component({
	data: {
        labels:[1,2,3],
        selected:[false,true,false]
    },
})
  • selected-group.json
{
    "component": true,
    "usingComponents": {},
    "componentGenerics":{
        "selectable": {
            "default": "./default"
        }
    }
}
  • default.wxml
<text>开发中...</text>
  • index.json
{
  "usingComponents": {
    "selected-group":"/components/generics/selected-group",
    "custom-checkbox":"/components/generics/custom-checkbox",
    "custom-radio":"/components/generics/custom-radio"
  }
}
  • index.wxml
<view>
<!--   generic:xxx="yyy" yyy是静态值 --> 
    <selected-group generic:selectable="custom-checkbox"></selected-group>
    <selected-group generic:selectable="custom-radio"></selected-group>
  	//对应default.wxml
    <selected-group generic:selectable="default"></selected-group>
</view>

截屏2021-09-25 上午1.47.34
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,类与继承-抽象类有以下几个关键点。首先,继承是指一个类可以继承自另一个类。被继承的类被称为父类/超类/基类,而继承其他类的类被称为子类。继承使得子类可以拥有父类中所有的成员(成员变量和成员方法),从而提高了代码的复用性。 其次,当子类继承自一个抽象类时,子类必须重写父类所有的抽象方法,否则该子类也必须声明为抽象类。最终,必须有子类实现该父类的抽象方法,否则从最初的父类到最终的子类都不能创建对象,失去了继承的意义。 一个示例代码如下: ``` public abstract class Animal { public abstract void run(); } public class Cat extends Animal { public void run() { System.out.println("小猫在墙头走~~~"); } } public class CatTest { public static void main(String[] args) { Cat c = new Cat(); c.run(); } } ``` 在上述代码中,Animal是一个抽象类,其中定义了一个抽象方法run。Cat类继承自Animal类,并且重写了run方法。在CatTest类的main方法中,创建了一个Cat对象并调用了run方法。 更多关于Java类与继承-抽象类的知识,可以参考Java基础教程之接口的继承与抽象类。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [java面向对象基础——继承、抽象类](https://blog.csdn.net/qq_42538127/article/details/115426682)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [【JavaSe】面向对象篇(六) 抽象类](https://blog.csdn.net/qq_41744145/article/details/100023046)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Java基础教程之接口的继承与抽象类](https://download.csdn.net/download/weixin_38516270/12808613)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值