微信小程序动态触发点击事件
2018-10-12 本文已影响72人
肉肉要次肉
微信展示列表效果借助于 wx:for
通常我们在静态创建一个view或是button,他对应的点击事件很简单
data:image/s3,"s3://crabby-images/7a979/7a97976f219b208f627014049f39d36cbf0e6ab0" alt=""
.wxml文件代码示例:
data:image/s3,"s3://crabby-images/166a4/166a4bdfba2b388070e54c003d01445db43eded8" alt=""
红框里的都是每个view,对应绑定的点击方法名字,接下来,我们在.js文件中分别来实现这些对应的点击方法
data:image/s3,"s3://crabby-images/1a494/1a494a108120f95b25a09bd8afff010029b9a218" alt=""
那以上是静态实现点击事件,那列表的时候如何实现动态触发点击事件呢?
动态触发点击事件
给有点击事件的组件添加一个 data-any 属性,any可以是任意数据类型,any的名称可以自己任意定义
这里有一个例子:
data:image/s3,"s3://crabby-images/76613/76613a7011c712a3ce75c496ce308da33d7cc7d6" alt=""
.wxml文件代码:
data:image/s3,"s3://crabby-images/5de9b/5de9bee9e39c411c4b7a9dc43a367ce1ebeb03d7" alt=""
这里的data-any,双引号里的值,
item:表示对象全部的值
item.xx:表示数组中某一个对象当中对应的某个数据
index:表示数组下标
data:image/s3,"s3://crabby-images/bee41/bee41cb48c674d46e08a293107b3179c5cde4c9d" alt=""
在if(indf==0)这里,因为.wxml文件中,定义的是index下标,那如果改成item,就可以写成
if(indf.title=="全部订单"),或者if(indf.index ==0)这样
效果图如下:
data:image/s3,"s3://crabby-images/06118/061184bd8631d2a12e3488c7f66cea4e53c12700" alt=""
这里,在额外的讲一下.js文件代码图片中,定义接收.wxml组件data中数据
var id = e.currentTarget.dataset.pid;
var indf = e.currentTarget.dataset.indd;
这里说一下.currentTarget和.target区别
e.currentTarget:指的是注册了事件监听器的对象
e.target:指的是该对象里的子对象,也是触发这个事件的对象