经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
小程序:自定义组件的实现方法
来源:cnblogs  作者:伟笑  时间:2018/10/10 9:03:00  对本文有异议

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

  图1                        图2

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

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

  1.   <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>
  2.   </view>
  1. .wx_dialog_container{
  2.   width: 100%;
  3.   height: 100%;
  4.   z-index: 999;
  5. }.wx-mask{
  6.   position: fixed;z-index: 1000;top: 0;right: 0;left: 35%;bottom: 0;background: rgba(0, 0, 0, 0.3);
  7. }.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;
  8. }.wx-dialog .li{display: block;font-size: 18px;margin-top:28px;margin-left:154px;
  9. }
  1. Component({
  2.   properties: {
  3.     
  4.   },
  5.   data: {
  6.     isShow: false,
  7.     animationData: {},
  8.     color:"#000",
  9.     items:[
  10.       { department: '研发部'},
  11.       { department: '设计部' },
  12.       { department: '人事部'},
  13.       { department: '销售部' },
  14.       { department: '市场运营部' },
  15.     ]
  16.   },
  17.  
  18.   methods: {
  19.     show: function () {      this.setData({
  20.         isShow: true  });
  21.     },
  22.   
  23.     close: function () {      this.setData({
  24.         isShow: false  })
  25.     },  // 自定义组件与页面之间的数据通信groupClick: function (e){      var group = this.data.items[e.target.dataset.index]
  26.       console.log(group)      // 使用 triggerEvent 方法触发自定义组件事件,指定事件名、detail对象和事件选项  this.triggerEvent('okEvent', { group}, {}) 
  27.       
  28.       this.setData({
  29.         isShow: false  })
  30.     },
  31.  
  32.   },
  33. })
  1. {  "component": true}

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

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

  • 首先要知道你点击的是列表中的哪个部门,所有要为列表元素添加一个 groupClick事件 打印出事件对象 e ,我们发现我们要的数据在e.target.dataset.index里

  • 已经得到数据对象了,下一步就是想办法把它传递给 index页面更新数据。在当前页面想要获取组件中的某一状态,需要使用到this.triggerEvent(' ',{},{}),第一个参数是自定义事件名称,所以还要在组件身上绑定个自定义事件,第二个对象就是你要传递的数据,第三个一般不用(代码参见标黄部分)

  • 最后就是在页面的index.js中定义这个事件来接收dialog的数据,并打印出 e 找到数据更新数据。(如下代码)

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

 

三、最后一个小知识

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

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

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

            

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号