微信小程序 制作小组件
对于我们日常中一些公共的东西可以封装成组件,然后在各个页面使用。对于小程序,我们也可以封装我们需要的一些公共的东西。
这里我们讲解一个小插件。
如上图所示,一个小插件,单击是展开,在单击关闭的时候,按钮关闭。
页面的WXML (APP.wxml)
<template> <view> <view> <view> <view></view> <image src="https://m.dev.vd.cn/static/xcx/v1/goo/md_logo.png"></image> </view> <view> <navigator url="../tua/home"> <view> <view><image src="https://m.dev.vd.cn/static/xcx/v1/goo/firsticon.png"></image></view> <view>首页</view> </view> </navigator> <navigator url="../ord/list"> <view> <view><image src="https://m.dev.vd.cn/static/xcx/v1/goo/orderIcon.png"></image></view> <view>订单</view> </view> </navigator> <navigator url="../usr/center"> <view> <view><image src="https://m.dev.vd.cn/static/xcx/v1/goo/myself.png"></image></view> <view>我的</view> </view> </navigator> <view> <image src="https://m.dev.vd.cn/static/xcx/v1/goo/delAllIcon.png" bindtap="closeAllIcon"></image> </view> </view> </view> </view> <view> <image src="https://m.dev.vd.cn/static/xcx/v1/goo/md_logo.png" bindtap="showAllIcon"></image> </view> </template>
这里主要是插件的压面展示效果,都写在<template>标签里面就可以了。
页面的JS (APP.js)
var iconList = {}; //设置一个对象名字存放数据 iconList.Wdg= { //存放要给VIEW层的页面数据,closeAllIcon ,showAllIcon 是对应的方法 data: { index: 0, close:0 }, closeAllIcon: function(e){ this.setData({ close:1 }) }, showAllIcon :function(e){ this.setData({ close:0 }) } }; module.exports=iconList //将接口的进行暴露,方便在外面调用
接下来封装好了,就是该怎么使用了。
在需要的WXML页面:
通过 引入斤页面,再通过
<template is="widget-dialog-iconList" data="{{你要传到页面的数据}}"></template>
进行使用。
在需要的WXML页面:
通过var iconList = require('../wdg/iconList');引入对应的JS
var util= require('../../util/util'); var Page = new util.Page({ Wdgs: [iconList.Wdg] });
引入对应文件。