本文是一篇JsRender的实用入门教程,实例讲述了tag else使用、循环嵌套访问父级数据等知识点。分享给大家供大家参考。具体如下:
前言
JsRender是一款基于jQuery的JavaScript模版引擎,它具有如下特点:
· 简单直观
· 功能强大
· 可扩展的
· 快如闪电
这些特性看起来很厉害,但几乎每个模版引擎,都会这么宣传。。。
由于工作需要,小菜才接触到此款模版引擎。使用了一段时间,发现它确实比较强大,但小菜觉得有些地方强大的过头了,反倒让人觉得很难理解。
另一方面,JsRender的官方文档比较详细,但其他资料出奇的少,遇到点什么问题,基本搜不到,不仅仅是相关问题搜不到,几乎就是没有结果。
再加上JsRender有些地方确实是不好理解,所以急需小菜分享一些“最佳实践”。
基于最近一段时间的使用,小菜总结了一些实用经验,当然,这些经验在官方文档上是找不到的。
嵌套循环使用#parent访问父级数据(不推荐)
序号 | 姓名 | 家庭成员 |
---|
<script><br /> //数据源<br /> var dataSrouce = [{<br /> name: "张三",<br /> family: [<br /> "爸爸",<br /> "妈妈",<br /> "哥哥"<br /> ]<br /> },{<br /> name: "李四",<br /> family: [<br /> "爷爷",<br /> "奶奶",<br /> "叔叔"<br /> ]<br /> }];<br /> <br /> //渲染数据<br /> var html = $("#testTmpl").render(dataSrouce);<br /> $("#list").append(html);<br /> <br /> </script>
嵌套循环使用参数访问父级数据(推荐)
序号 | 姓名 | 家庭成员 |
---|
<script><br /> //数据源<br /> var dataSrouce = [{<br /> name: "张三",<br /> family: [<br /> "爸爸",<br /> "妈妈",<br /> "哥哥"<br /> ]<br /> },{<br /> name: "李四",<br /> family: [<br /> "爷爷",<br /> "奶奶",<br /> "叔叔"<br /> ]<br /> }];<br /> <br /> //渲染数据<br /> var html = $("#testTmpl").render(dataSrouce);<br /> $("#list").append(html);<br /> <br /> </script>
自定义标签(custom tag)中使用else(强烈不推荐)
名称 | 单价 |
---|
<script><br /> //数据源<br /> var dataSrouce = [{<br /> name: "苹果",<br /> price: 108<br /> },{<br /> name: "鸭梨",<br /> price: 370<br /> },{<br /> name: "桃子",<br /> price: 99<br /> },{<br /> name: "菠萝",<br /> price: 371<br /> },{<br /> name: "橘子",<br /> price: 153<br /> }];<br /> <br /> //自定义标签<br /> $.views.tags({<br /> "isShow": function(price){<br /> var temp=price+''.split('');<br /> <br /> if(this.tagCtx.props.status === 0){<br /> //判断价格是否为水仙花数,如果是,则显示,否则不显示<br /> if(price==(Math.pow(parseInt(temp[0],10),3)+Math.pow(parseInt(temp[1],10),3)+Math.pow(parseInt(temp[2],10),3))){<br /> return this.tagCtxs[0].render();<br /> }else{<br /> return this.tagCtxs[1].render();<br /> }<br /> }else{<br /> return "";<br /> }<br /> <br /> }<br /> });<br /> <p> //渲染数据<br /> var html = $("#testTmpl").render(dataSrouce);<br /> $("#list").append(html);<br /> <br /> </script>
用helper代替自定义标签(推荐)
名称 | 单价 |
---|
<script><br /> //数据源<br /> var dataSrouce = [{<br /> name: "苹果",<br /> price: 108<br /> },{<br /> name: "鸭梨",<br /> price: 370<br /> },{<br /> name: "桃子",<br /> price: 99<br /> },{<br /> name: "菠萝",<br /> price: 371<br /> },{<br /> name: "橘子",<br /> price: 153<br /> }];<br /> <br /> //Helper<br /> $.views.helpers({<br /> "isShow": function(price){<br /> var temp=price+''.split('');<br /> if(price==(Math.pow(parseInt(temp[0],10),3)+Math.pow(parseInt(temp[1],10),3)+Math.pow(parseInt(temp[2],10),3))){<br /> return true;<br /> }else{<br /> return false;<br /> }<br /> }<br /> }); <p> //渲染数据<br /> var html = $("#testTmpl").render(dataSrouce);<br /> $("#list").append(html);<br /> <br /> </script>
完整实例代码点击此处本站下载。
希望本文所述对大家JsRender程序设计的学习有所帮助。

全角英文字母转换为半角形式的实用技巧在现代生活中,我们经常会接触到英文字母,在使用电脑、手机等设备时也经常需要输入英文字母。然而,有时候我们会遇到全角英文字母的情况,而我们需要使用的是半角形式。那么,如何将全角英文字母转换为半角形式呢?下面就为大家介绍一些实用的技巧。首先,全角英文字母和数字是指在输入法中占据一个全角位置的字符,而半角英文字母和数字则是占据一

PyCharm新手指南:删除项目的实用技巧PyCharm是一款功能强大的Python集成开发环境(IDE),在进行项目开发时,有时候需要删除项目或项目中的文件。本文将介绍在PyCharm中删除项目的实用技巧,并提供具体的代码示例帮助新手更好地理解和应用。1.删除项目删除项目意味着删除整个项目文件夹,这在我们需要清理或重建项目时非常有用。在PyCharm中删

Vue.js是一款流行的JavaScript前端框架,目前已经推出了最新的版本——Vue3,新版Vue在性能、体积以及开发体验上均有所提升,受到越来越多的开发者欢迎。本文将介绍如何使用Vue3制作一个简单的图片裁剪器。首先,我们需要创建一个Vue项目并安装所需的插件。可以使用VueCLI来创建项目,也可以手动搭建。这里我们以使用VueCLI的方式为例:#

Go-zero是一款优秀的Go语言框架,它提供了一整套解决方案,包括RPC、缓存、定时任务等功能。事实上,使用go-zero建立一个高性能的服务非常简单,甚至可以在数小时内从入门到精通。本文旨在介绍使用go-zero框架构建高性能服务的过程,并帮助读者快速掌握该框架的核心概念。一、安装和配置在开始使用go-zero之前,我们需要安装它并配置一些必要的环境。1

从零开始学习Django框架:实用教程和示例Django是一种流行的PythonWeb应用程序框架,它简化了网站的开发过程。它提供了一套强大的工具和库,帮助开发者构建高效、可扩展和安全的Web应用程序。对于初学者来说,学习Django可能会有些困难,但是通过一些实用的教程和示例,你可以快速上手并了解这个框架的核心概念和用法。本文将带你逐步学习Django框

快速入门:使用Go语言函数实现简单的数据可视化功能随着数据的快速增长和复杂性的提高,数据可视化成为了数据分析和数据表达的重要手段。在数据可视化中,我们需要使用合适的工具和技术来将数据转化为易读且易理解的图表或图形。Go语言作为一种高效且易于使用的编程语言,在数据科学领域也有着广泛的应用。本文将介绍如何使用Go语言函数来实现简单的数据可视化功能。我们将使用Go

yum是一种常用的软件包管理工具,而gdb是一种强大的调试工具。下面是它们的使用教程:yum使用教程:安装软件包:使用yuminstall命令安装软件包。例如,要安装ApacheWeb服务器,可以运行yuminstallhttpd。升级软件包:使用yumupdate命令升级已安装的软件包。例如,运行yumupdate将升级系统中的所有软件包。删除软件包:使用yumremove命令删除软件包。例如,要删除ApacheWeb服务器,可以运行yumremovehttpd。搜索软件包:使用yumsear

随着科技的不断发展,人脸识别技术也越来越得到了广泛的应用。而在Web开发领域中,PHP是一种被广泛采用的技术,因此PHP中的人脸识别技术也备受关注。本文将介绍PHP中的人脸识别入门指南,帮助初学者快速掌握这一领域。一、什么是人脸识别技术人脸识别技术是一种基于计算机视觉技术的生物特征识别技术,其主要应用领域包括安防、金融、电商等。人脸识别技术的核心就是对人脸进


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能