微信小程序中data-key属性之数据传输(经验总结)
本文是的一点经验之谈
啥是data-key
微信小程序推出 data- 属性——自定义属性,为了更好的进行数据传递。
来说,data-key="{{...}}"
是获取页面中需要用的数据,往js文件(事件)中传—— 被绑定在其组件上的事件使用 也就是常说的dataset;(比如wx:for的view中的每一个项的name属性值)
而data-key="..."
是从data传到wxml页面中,一般都是在data中存在的属性才这样做,它就是为了“动态修改”data中的属性。
- 只有data-传的值才能在事件中被dataset接收,其余的“{{}}”只能使用
- detaildata-中不带{{}}时一般都是写好的值,只是用作不必用data中的数据!
怎么接收data-的值
如下
<view bindtap="SetData" data-name="mxc" data-age="18"> 获取数据 </view>
js中
Page({ data:{ name:'', age:0 }, SetData:function(e){ console.log(e); this.setData({ name:e.target.dataset.name }); console.log(this.data.name); } })
狼蚁网站SEO优化来说几点问题
上面的程序,在控制台输出data中的值在event.target.dataset中
我们看到,如愿以偿。
那能不能再currentTarget中输出?
准确的说,是能不能获取currentTarget中的值?
那肯定可以啦!
我们来看官方文档
从中可以看出一个很严重的问题当前组件 和 触发事件组件
我们都知道,触发事件有 bindtap 和 catchtap 两种。其中,bindtap可向上(父组件)传递事件
明白了吧?
, 要想更精确,就用currentTarget;要在一个大组件中有多个触发事件,就可以用target减少事件定义
说说data-绑定数据的坑
你如果在wxml中这么写
<view bindtap='like' data-id='{{laugh.id}}' data-createdBy='{{laugh.created_by}}'>
然后在js中接收
like(e){ console.log(e.currentTarget.dataset['createdBy']); }
是会出大问题的它报undefined!
在组件中可以定义数据,这些数据将会通过事件传递给 SERVICE。 书写方式 以data-开头,多个单词由连字符-链接,不能有大写(大写会自动转成小写)如data-element-type,最终在 event.currentTarget.dataset 中会将连字符转成驼峰elementType。
也就是说小程序自动转了,会把下划线转为大写,大写转为小写。。。(不知道坑了多少人)
like(e){ console.log(e.currentTarget.dataset['createdby']); }
改过之后,世界一片清净…
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程