时间:2021-05-18
web开发中,尤其使用react开发项目时,我们可以很方便的动态定义标签(jsx)
const props = { id: '', className: '', data-a: ''}<button {...props} />动态配置标签的好处一是所有逻辑在JS端控制,二是使得我们的模板非常规范,方便后续维护更新,碎片模板可以很好的控制,三是我们可以根据使用场景很方便的配置props的属性,这样在html结构输出的时候能够得到比较干净的结构
在小程序的开发中,却不能实现类似的功能,导致我们的动态标签通常非常的冗余,多余的属性全部展示在结构生成后
以button为例,我们知道button在小程序中有非常多的属性
如上所示,这里只是列举了一部分的属性
动态模板
我们的button动态模板写下来应该是这样的
配置
Page({ data: { option: { ... } }})<button size="{{option.size || 'default'}}" type="{{option.type || 'default'}}" plain="{{option.plain || false}}" value="{{option.value || '按钮'}}" ... .../>调试工具的输出结构
<button bindtap='' size='' type='' plain='' disabled=false open-typ='' hover-class='' .... />可以看到调试工具中输出的结构就会变得非常冗余,降低了开发效率,这种冗余的模板输出搞久了会吐的好吧。
可以使用模板语法区分不同场景的button,我知道会有很多这样的声音,但那不是动态模板。
解决问题
那要如何解决输出结构不冗余呢,说了这么多终于到了重点,其实真的只是一个很小的技巧,我的开发经历告诉我这是有效的,你也可以试试,将默认值统统换成 '',改版后的模板如下
<button size="{{option.size || ''}}" type="{{option.type || ''}}" plain="{{option.plain || ''}}" value="{{option.value || '按钮'}}" ... .../>这时你得到的模板就是一段漂亮的结构
<button value='按钮' />关注我们的开源小程序
https://github.com/webkixi/aotoo-xquery
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
众所周知,用户在打开微信小程序的时候,我们可以使用小程序自带的静默登录代码,获取用户的openid的,现在就分析来小程序的登录代码该如何写,才能确定的实现小程序
【网页制作学习】如何写网页,学习写网页需要我们掌握哪些知识?如何在网上制作自己的网页?下面就和小编一起来看看吧! 如何写网页,学习写网页需要我们掌握哪些知
【海报的设计制作】如何写海报设计文案?海报设计的主要内容有哪些?下面就和小编一起来看看吧! 如何写海报设计文案? 1.海报通常写在一张大纸上。首先,“海
大家都说“内容为王”,一篇高质量的文章会给自己的网站带来很多流量,但是如何写一篇高质量的文章呢?下面小编就教大家如何写一篇高质量的文章。在写高质量的文章之前,要
Tips:微信小程序可以在HbuilderX用HTML标签(如Ddiv、span等)写前端代码,也可以用微信小程序语法写(view、swiper标签),然后np