小程序如何写动态标签的实现方法


Posted in Javascript onFebruary 05, 2020

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
不用ajax实现点击文字即可编辑的方法
Dec 16 Javascript
JavaScript如何从listbox里同时删除多个项目
Oct 12 Javascript
Jquery下EasyUI组件中的DataGrid结果集清空方法
Jan 06 Javascript
原生js实现数字字母混合验证码的简单实例
Dec 10 Javascript
JavaScript的this关键字的理解
Jun 18 Javascript
jQuery动态添加可拖动元素完整实例(附demo源码下载)
Jun 21 Javascript
jQuery模仿京东/天猫商品左侧分类导航菜单效果
Jun 29 Javascript
打造自己的jQuery插件入门教程
Sep 23 Javascript
angular.js和vue.js中实现函数去抖示例(debounce)
Jan 18 Javascript
java和js实现的洗牌小程序
Sep 30 Javascript
微信小程序开发(三):返回上一级页面并刷新操作示例【页面栈】
Jun 01 Javascript
解决vue项目打包上服务器显示404错误,本地没出错的问题
Nov 03 Javascript
vue如何实现动态加载脚本
Feb 05 #Javascript
vue实现图片懒加载的方法分析
Feb 05 #Javascript
Vue组件基础用法详解
Feb 05 #Javascript
vue组件传值的实现方式小结【三种方式】
Feb 05 #Javascript
vue路由传参的基本实现方式小结【三种方式】
Feb 05 #Javascript
Vuex的API文档说明详解
Feb 05 #Javascript
如何实现iframe父子传参通信
Feb 05 #Javascript
You might like
Ajax+PHP 边学边练之四 表单
2009/11/27 PHP
PHP模糊查询的实现方法(推荐)
2016/09/06 PHP
PHP仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(上)
2017/05/26 PHP
PHP实现双链表删除与插入节点的方法示例
2017/11/11 PHP
PHP+Apache环境中如何隐藏Apache版本
2017/11/24 PHP
PHP数组对象与Json转换操作实例分析
2019/10/22 PHP
jQuery层次选择器选择元素使用介绍
2013/04/18 Javascript
JSON 数字排序多字段排序介绍
2013/09/18 Javascript
浅析XMLHttpRequest的缓存问题
2013/12/13 Javascript
jquery退出each循环的写法
2014/02/26 Javascript
yui3的AOP(面向切面编程)和OOP(面向对象编程)
2015/05/01 Javascript
把Node.js程序加入服务实现随机启动
2015/06/25 Javascript
jquery性能优化高级技巧
2015/08/24 Javascript
JavaScript学习笔记整理之引用类型
2016/01/22 Javascript
jQuery插件EasyUI获取当前Tab中iframe窗体对象的方法
2016/08/05 Javascript
微信小程序中使元素占满整个屏幕高度实现方法
2016/12/14 Javascript
详解JavaScript树结构
2017/01/09 Javascript
利用vscode调试编译后的js代码详解
2018/05/14 Javascript
从0到1构建vueSSR项目之node以及vue-cli3的配置
2019/03/07 Javascript
layui自己添加图片按钮并点击跳转页面的例子
2019/09/14 Javascript
layui 图片上传+表单提交+ Spring MVC的实例
2019/09/21 Javascript
Python中os.path用法分析
2015/01/15 Python
Python竟能画这么漂亮的花,帅呆了(代码分享)
2017/11/15 Python
Python设计模式之观察者模式简单示例
2018/01/10 Python
使用Python爬取最好大学网大学排名
2018/02/24 Python
python实现树形打印目录结构
2018/03/29 Python
python中嵌套函数的实操步骤
2019/02/27 Python
Python控制Firefox方法总结
2019/06/03 Python
python编写猜数字小游戏
2019/10/06 Python
python如何获取apk的packagename和activity
2020/01/10 Python
基于matplotlib中ion()和ioff()的使用详解
2020/06/16 Python
详解python中的异常和文件读写
2021/01/03 Python
精通CAD能手自荐书
2014/01/31 职场文书
员工安全责任书范本
2014/07/24 职场文书
教师三严三实对照检查材料
2014/09/25 职场文书
人事主管岗位职责
2015/02/04 职场文书