• 小程序如何写动态标签


    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,我知道会有很多这样的声音,但那不是动态模板。

    电脑刺绣绣花厂 http://www.szhdn.com 广州品牌设计公司https://www.houdianzi.com

    解决问题

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

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

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

    <button value='按钮' />
  • 相关阅读:
    shell脚本的常用参数
    Qt中使用Protobuf简单案例(Windows + msvc)
    使用PicGo和Typora写Markdown
    CentOS7安装protobuf(C++)和简单使用
    protobuf编译、安装和简单使用C++ (Windows+VS平台)
    protocol buffers 文档(一)-语法指导
    Base64编码和其在图片的传输的应用
    Qt程序打包发布
    Qt中的Label和PushButton背景图自动缩放设置
    TCP的粘包和拆包问题及解决
  • 原文地址:https://www.cnblogs.com/xiaonian8/p/13825863.html
Copyright © 2020-2023  润新知