小程序如何写动态标签

web开发中,尤为使用react开发项目时,咱们能够很方便的动态定义标签(jsx)html

const props = {
  id: '',
  className: '',
  data-a: ''
}
<button {...props} />

动态配置标签的好处一是全部逻辑在JS端控制,二是使得咱们的模板很是规范,方便后续维护更新,碎片模板能够很好的控制,三是咱们能够根据使用场景很方便的配置props的属性,这样在html结构输出的时候可以获得比较干净的结构 react

在小程序的开发中,却不能实现相似的功能,致使咱们的动态标签一般很是的冗余,多余的属性所有展现在结构生成后 git

以button为例,咱们知道button在小程序中有很是多的属性 github

image.png

如上所示,这里只是列举了一部分的属性web

动态模板

咱们的button动态模板写下来应该是这样的 小程序

配置工具

Page({
  data: {
    option: {
      ...
    }
  }
})
<button
  size="{{option.size || 'default'}}"
  type="{{option.type || 'default'}}"
  plain="{{option.plain || false}}"
  value="{{option.value || '按钮'}}"
  ...
  ...
/>

调试工具的输出结构spa

<button bindtap='' size='' type='' plain='' disabled=false open-typ='' hover-class='' .... />

能够看到调试工具中输出的结构就会变得很是冗余,下降了开发效率,这种冗余的模板输出搞久了会吐的好吧。调试

可使用模板语法区分不一样场景的button,我知道会有不少这样的声音,但那不是动态模板。code

解决问题

那要如何解决输出结构不冗余呢,说了这么多终于到了重点,其实真的只是一个很小的技巧,个人开发经历告诉我这是有效的,你也能够试试,将默认值通通换成 '',改版后的模板以下

<button
  size="{{option.size || ''}}"
  type="{{option.type || ''}}"
  plain="{{option.plain || ''}}"
  value="{{option.value || '按钮'}}"
  ...
  ...
/>

这时你获得的模板就是一段漂亮的结构

<button value='按钮' />

关注咱们的开源小程序

https://github.com/webkixi/ao...

相关文章
相关标签/搜索