微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递问题


Posted in Javascript onOctober 09, 2018

首先我们在pages文件夹下创建components目录用于存放自定义组件。如图所示,以我创建的dialog组件为例,自定义组件的格式与页面一样,分为4个文件。

  微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递问题 

图1                      

微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递问题

  图2

如上图2所示,假如index页面有一个按钮触发点击事件后弹出dialog,并且当点击某个部门时,将dialog关闭,并将部门名称与红色标题同步。

一、首先把dialog组件的样式写好,并在index页面相应的位置引用。以下就是代码啦(分别为:wxml、wxss、js、json)

<view class='wx_dialog_container' hidden="{{!isShow}}">
 <view class='wx-mask' bindtap='close'></view>
 <view class='wx-dialog'>
 <text class='li' bindtap='groupClick' wx:for="{{items}}" data-index='{{index}}' wx:for-item="item">{{item.department}}</text> 
 </view>
 </view>

.wx_dialog_container{
 width: 100%;
 height: 100%;
 z-index: 999;
}
.wx-mask{
 position: fixed;
 z-index: 1000;
 top: 0;
 right: 0;
 left: 35%;
 bottom: 0;
 background: rgba(0, 0, 0, 0.3);
}
.wx-dialog{
 position: fixed;
 min-width: 528rpx;
 height: 100%;
 left: 0;
 top:314px;
 -webkit-transform: translate(-50%, -50%);
 transform: translate(-50%, -50%);
 background-color: #FFFFFF;
 text-align:left;
}
.wx-dialog .li{
 display: block;
 font-size: 18px;
 margin-top:28px;
 margin-left:154px;
}

Component({
 properties: {
 
 },
 data: {
 isShow: false,
 animationData: {},
 color:"#000",
 items:[
 { department: '研发部'},
 { department: '设计部' },
 { department: '人事部'},
 { department: '销售部' },
 { department: '市场运营部' },
 ]
 },

 methods: {
 show: function () {
 this.setData({
 isShow: true
 });
 },
 
 close: function () {
 this.setData({
 isShow: false
 })
 },

 // 自定义组件与页面之间的数据通信
 groupClick: function (e){
 var group = this.data.items[e.target.dataset.index]
 console.log(group)
 // 使用 triggerEvent 方法触发自定义组件事件,指定事件名、detail对象和事件选项
 this.triggerEvent('okEvent', { group}, {})
 
 
 this.setData({
 isShow: false

 })
 },
 
 },
})

{
 "component": true
}

最后一步别忘了在你相应的页面中引用它,注意:自定义组件名称要和components目录下的一致。如下图我在index.wxml中使用它

微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递问题

二、组件与页面怎么数据通信呢?

•首先要知道你点击的是列表中的哪个部门,所有要为列表元素添加一个 groupClick事件 打印出事件对象 e ,我们发现我们要的数据在e.target.dataset.index里
•已经得到数据对象了,下一步就是想办法把它传递给 index页面更新数据。在当前页面想要获取组件中的某一状态,需要使用到this.triggerEvent(' ',{},{}),第一个参数是自定义事件名称,所以还要在组件身上绑定个自定义事件,第二个对象就是你要传递的数据,第三个一般不用(代码参见标黄部分)
•最后就是在页面的index.js中定义这个事件来接收dialog的数据,并打印出 e 找到数据更新数据。(如下代码) 

// 接受triggerEvent 方法触发的自定义组件事件来更新同步数据
 okEvent: function (e) {
 console.log(e)
 this.setData({
 groupName: e.detail.group.department
 })
 
 },

三、最后一个小知识

如果想在 index.js逻辑中引用dialog.js 中methods里定义好的方法,需要在index.js 中添加如下代码

onReady: function () {
 this.dialog = this.selectComponent('#dialog');
 },

比如:我把show、close 方法定义在了组件中的methods 里,要在index页面中触发某个时间让dialog展示,只需在index.js 中这么写即可。

微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递问题

总结

以上所述是小编给大家介绍的微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
HTTP状态代码以及定义(解释)
Feb 02 Javascript
javascript function、指针及内置对象
Feb 19 Javascript
jQuery 使用手册(六)
Sep 23 Javascript
jquery ui 1.7 ui.tabs 动态添加与关闭(按钮关闭+双击关闭)
Apr 01 Javascript
jQuery学习笔记之jQuery的DOM操作
Dec 22 Javascript
解析使用js判断只能输入数字、字母等验证的方法(总结)
May 14 Javascript
js实现省市联动效果的简单实例
Feb 10 Javascript
使用原生js+canvas实现模拟心电图的实例
Sep 20 Javascript
Node.js学习之TCP/IP数据通讯(实例讲解)
Oct 11 Javascript
Vue实现美团app的影院推荐选座功能【推荐】
Aug 29 Javascript
Ant Design Vue 添加区分中英文的长度校验功能
Jan 21 Javascript
浅析vue-router实现原理及两种模式
Feb 11 Javascript
从零开始封装自己的自定义Vue组件
Oct 09 #Javascript
vue axios 简单封装以及思考
Oct 09 #Javascript
angularJS实现不同视图同步刷新详解
Oct 09 #Javascript
对angular 实时更新模板视图的方法$apply详解
Oct 09 #Javascript
AngularJs返回前一页面时刷新一次前面页面的方法
Oct 09 #Javascript
详解js模板引擎art template数组渲染的方法
Oct 09 #Javascript
angular4强制刷新视图的方法
Oct 09 #Javascript
You might like
基于JQuery+PHP编写砸金蛋中奖程序
2015/09/08 PHP
php实现的递归提成方案实例
2015/11/14 PHP
php 在字符串指定位置插入新字符的简单实现
2016/06/28 PHP
PHP常量DIRECTORY_SEPARATOR原理及用法解析
2020/11/10 PHP
javascript vvorld 在线加密破解方法
2008/11/13 Javascript
js 自制滚动条的小例子
2013/03/16 Javascript
如何获取网站icon有哪些可行的方法
2014/06/05 Javascript
在JS方法中返回多个值的方法汇总
2015/05/20 Javascript
常用DOM整理
2015/06/16 Javascript
JavaScript_ECMA5数组新特性详解
2016/06/12 Javascript
Bootstrap模态窗口源码解析
2017/02/08 Javascript
从零学习node.js之利用express搭建简易论坛(七)
2017/02/25 Javascript
vue2.0中click点击当前li实现动态切换class
2017/06/21 Javascript
angularJS实现动态添加,删除div方法
2018/02/27 Javascript
vue中mint-ui的使用方法
2018/04/04 Javascript
vue动画打包后失效问题的解决方法
2018/09/18 Javascript
浅析vue 函数配置项watch及函数 $watch 源码分享
2018/11/22 Javascript
JavaScript链式调用实例浅析
2018/12/19 Javascript
微信小程序如何实现点击图片放大功能
2020/01/21 Javascript
[17:00]DOTA2 HEROS教学视频教你分分钟做大人-帕克
2014/06/10 DOTA
压缩包密码破解示例分享(类似典破解)
2014/01/17 Python
python读取TXT每行,并存到LIST中的方法
2018/10/26 Python
python面向对象实现名片管理系统文件版
2019/04/26 Python
Python爬取爱奇艺电影信息代码实例
2019/11/26 Python
TensorBoard 计算图的查看方式
2020/02/15 Python
OpenCV Python实现拼图小游戏
2020/03/23 Python
HTML5 Canvas渐进填充与透明实现图像的Mask效果
2013/07/11 HTML / CSS
世界最大的私人旅行指南出版商:孤独星球
2016/08/23 全球购物
凯伦·米莲女装网上商店:Karen Millen
2017/11/07 全球购物
幼儿园教师国培感言
2014/02/02 职场文书
三八红旗集体先进事迹材料
2014/05/22 职场文书
三年级上册科学教学计划
2015/01/21 职场文书
授权委托书
2015/01/28 职场文书
2015年感恩父亲节活动策划方案
2015/05/05 职场文书
Redis RDB技术底层原理详解
2021/09/04 Redis
漫画「日和酱的要求是绝对的」第3卷封面公开
2022/03/21 日漫