我的编程空间,编程开发者的网络收藏夹
学习永远不晚

微信小程序怎么自定义组件Component使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

微信小程序怎么自定义组件Component使用

本篇内容介绍了“微信小程序怎么自定义组件Component使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

1- 前言

在本文中你将收获

  • 小程序如何使用自定义组件

  • 自定义组件之间的传值

  • 自定义组件中插槽的使用

2- 组件文件新建

2.1 定义组件

在根目录新建components文件夹,建立cell 文件夹,右击创建cell的Component组件

  • cell.js

  • cell.wxml

  • cell.json

  • cell.wxss

2.2 注册组件

页面的xxx.json ,usingComponent注册

"usingComponents": {"item":"/components/item/item"}

2.3 使用组件

<item></item>

2.4 图参考

微信小程序怎么自定义组件Component使用

微信小程序怎么自定义组件Component使用

3- 外部类和样式隔离

3.1定义组件

cell.wxml 文件

<view class="cell cell-class"></view>

cell.wxss

.cell{  color: tomato;}.mycell{  color: #f70;  line-height: 120rpx !important;}

cell.js 文件

    options:{        styleIsolation:'isolated',  },  //通过组件的外部类实现父组件控制自己的样式  externalClasses:["cell-class"],

3.2 使用组件

<cell></cell><cell cell-class="mycell"></cell>

微信小程序怎么自定义组件Component使用

3.3 图解释

微信小程序怎么自定义组件Component使用

4- 组件插槽

4.1 默认插槽

cell.wxml

 <view class="cell">  我是cell组件  <slot></slot></view>

cell.js

    options:{    //允许多个插槽    multipleSlots:true,  },

cell.wxss

.cell{  height: 88rpx;  line-height: 88rpx;  border-bottom: 1rpx solid #cccccc;}

使用cell组件

<cell>  <text>放假</text>  <text>快点到来</text></cell>

微信小程序怎么自定义组件Component使用

4.2 命名多插槽

cell.wxml

 <view class="cell cell-class">  <slot name="pre"></slot>  我是cell组件  <slot></slot>  <slot name="next"></slot></view>

cell.js

    options:{    //允许多个插槽    multipleSlots:true,  },

cell.wxss

.cell{  height: 88rpx;  line-height: 88rpx;  border-bottom: 1rpx solid #cccccc;}

com.wxml

<!-- 插槽 --><cell>  <text slot="pre">????‍????</text>  <text slot="next">????‍????</text>  <text>放假</text>  <text>快点到来</text></cell><cell cell-class="mycell">  <text slot="next">????</text>  <text slot="pre">????‍</text>  <text>做核酸</text>  <text>今天要做</text></cell>

微信小程序怎么自定义组件Component使用

5- 组件传参

5.1 父传子

5.1.1 定义组件

cell.wxml

<view class="cell">  <text>{{title}}</text>  <text>{{num}}</text></view>

cell.js

// components/cell/cell.jsComponent({    options:{        styleIsolation:'isolated',    //允许多个插槽    multipleSlots:true,  },    properties: {    title:{      type:String,      value:""    },    num:{      type:Number,      value:1    }  },    data: {    //定义组件自己的数据count    count:1  },  })
5.1.2 使用组件

com.wxml

<cell title="做核酸" num="{{5}}"></cell><cell title="烦呐"></cell>
5.1.3 图解

微信小程序怎么自定义组件Component使用

5.2 子传参父

5.2.1 定义组件

cell.wxml

<view class="cell" bindtap="tapHd">  <text>{{title}}</text>  <text>{{count}}</text></view>

cell.js

// components/cell/cell.jsComponent({    options:{        styleIsolation:'isolated',    //允许多个插槽    multipleSlots:true,  },    properties: {    title:{      type:String,      value:""    },    num:{      type:Number,      value:1    }  },    data: {    //定义组件自己的数据count    count:1  },  lifetimes:{    //在组件生命周期attached挂载更新count    attached(){      console.log(this.data);      //count 的值为父组件传递的num值      this.setData({count:this.data.num})    }  },    methods: {    tapHd(){      this.setData({count:this.data.count+5})      //发送一个事件      this.triggerEvent("cellclick",this.data.count)    }  }})
5.2.2 使用组件

com.wxml

 <view class="cell" bindtap="tapHd">  <text>{{title}}</text>  <text>{{count}}</text></view>
5.2.3 图解

微信小程序怎么自定义组件Component使用

6- 案例item组件

6.1 定义组件

  • 首先在根目录下创建一个专门放自定义组件的文件夹;

  • 然后在小程序编辑器里,右键,新建Component;

微信小程序怎么自定义组件Component使用

<!--components/item/item.wxml--><navigator class="item itemclass" url="{{url}}" open-type="{{openType}}" bindtap="itemclick">  <view class="icon" wx:if="{{icon}}">    <image class="lazy" data-src="{{icon}}" mode="aspectFill"/>  </view>  <view class="content">    <view class="title" wx:if="{{title}}">      {{title}}    </view>    <slot name="title" wx:else ></slot>    <view class="right" wx:if="{{!showrslot}}">      <view class="tip">{{tip}}</view>      <view class="badge" wx:if="{{badge}}">      <view wx:if="{{badge===true}}" class="dot">  </view>        <view wx:else class="redbadge">{{badge}}</view>       </view>      <view class="arrow"></view>    </view>    <slot name="right" wx:else></slot>  </view></navigator>
.item{  line-height: 88rpx;  display: flex;  align-items: center;  justify-content: space-between;}.icon{  margin-left: 30rpx;  margin-right: 30rpx;  height: 100%;  display: flex;  align-items: center;}.icon image{  width: 60rpx;  height: 60rpx;}.content{  padding: 0 30rpx;  border-bottom: 1rpx solid #ccc;  display: flex;  flex: 1;}.title{  flex: 1;  color: #333;  font-size: 35rpx;}.right{  display: flex;  align-items: center;}.right .arrow{  height: 25rpx;  width: 25rpx;  border-top: 3rpx solid #999;  border-right: 3rpx solid #999;  transform: rotate(45deg);}.tip{  color: #999;  font-size: 28rpx;}.dot{  height: 15rpx;  width: 15rpx;  background-color: #f30;  margin-left: 15rpx;  border-radius: 50%;}.redbadge{  font-size: 20rpx;  padding: 5rpx;  background-color: #f30;  width: 30rpx;  max-height: 30rpx;  line-height: 30rpx;  color: #fff;  text-align: center;  margin-left: 15rpx;  border-radius: 20rpx;}

6.2 使用组件

引入组件:在页面的 json 文件中进行引用声明;

微信小程序怎么自定义组件Component使用

<!-- 引用组件的json文件 -->{  "usingComponents": {    "cell": "/components/cell/cell"  }}

在页面的 wxml 中像使用基础组件一样使用自定义组件(名字和声明的保持一致)

<!-- 引用组件的wxml文件 --><!--pages/component/component.wxml--><item title="支付" icon="/images/icon01.png"></item><item title="相册" icon="/images/icon02.png"></item><item title="设置" ></item><item title="朋友圈" icon="/images/icon03.png" badge="{{true}}" tip="10条消息未读"></item><item title="卡包" icon="/images/icon04.png" badge="{{12}}" tip="12条消息未读"></item><item title="服务" icon="/images/icon05.png" showrslot="{{true}}">  <switch checked="true" slot="right" /></item><item><view slot="title">插槽title</view></item><item title="新闻" icon="/images/icon07.png" url="/pages/index/index" open-type="switchTab"></item><item title="life" icon="/images/icon08.png" url="/pages/life/life" ></item><item title="消息" icon="/images/icon06.png" showrslot="{{true}}" itemclass="myitem">  <switch checked="true" slot="right" /></item>
.myitem{  line-height: 120rpx !important;  background-color: #f0f0f0;}

微信小程序怎么自定义组件Component使用

“微信小程序怎么自定义组件Component使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

微信小程序怎么自定义组件Component使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

微信小程序怎么自定义组件Component使用

本篇内容介绍了“微信小程序怎么自定义组件Component使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1- 前言在本文中你将收获小程序
2023-07-05

微信小程序自定义组件Component的代码详解

这篇文章主要给大家介绍了关于微信小程序自定义组件Component的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
2023-03-02

微信小程序怎么自定义组件

这篇文章主要讲解了“微信小程序怎么自定义组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序怎么自定义组件”吧!组件模版和样式类似于页面,自定义组件拥有自己的 wxml 模版和 wx
2023-06-26

微信小程序怎么自定义地址组件

本文小编为大家详细介绍“微信小程序怎么自定义地址组件”,内容详细,步骤清晰,细节处理妥当,希望这篇“微信小程序怎么自定义地址组件”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。项目需求需要调用后台传过来的地址,存储
2023-07-02

微信小程序怎么使用自定义组件封装原生image组件

本文小编为大家详细介绍“微信小程序怎么使用自定义组件封装原生image组件 ”,内容详细,步骤清晰,细节处理妥当,希望这篇“微信小程序怎么使用自定义组件封装原生image组件 ”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习
2023-06-26

微信小程序如何自定义tabbar组件

这篇文章主要讲解了“微信小程序如何自定义tabbar组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序如何自定义tabbar组件”吧!由于项目需求,必须自己写组件:第一步:在App
2023-06-14

微信小程序中如何自定义组件

这篇文章将为大家详细讲解有关微信小程序中如何自定义组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在微信小程序开发过程中,对于一些可能在多个页面都使用的页面模块,可以把它封装成一个组件,以提高开发效率。
2023-06-29

微信小程序组件间关系怎么定义和使用

这篇文章主要介绍“微信小程序组件间关系怎么定义和使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“微信小程序组件间关系怎么定义和使用”文章能帮助大家解决问题。  组件间关系  定义和使用组件间关系 
2023-06-26

微信小程序中如何自定义创建和使用组件

在微信小程序中,可以通过使用自定义组件来实现对页面上重复使用的部分进行封装和复用。下面是在微信小程序中自定义创建和使用组件的步骤:创建组件文件:在微信小程序的项目目录中,新建一个文件夹用于存放组件文件,例如名为"components"。在该
微信小程序中如何自定义创建和使用组件
2024-04-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录