knockout.js模板绑定之利用Underscore.js模板引擎示例

2023-10-28 05:38

本文主要是介绍knockout.js模板绑定之利用Underscore.js模板引擎示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

View代码

复制代码
 1 <h1>People</h1>
 2 <ul data-bind="template: { name: 'peopleList' }"></ul>
 3 
 4 <script type="text/html" id="peopleList">
 5     <% _.each(people(), function(person) { %>
 6         <li>
 7             <b data-bind="text: person.name"></b> is <%= person.age %> years old
 8         </li>
 9     <% }) %>
10 </script>
复制代码

ViewModel

复制代码
1 var viewModel = {
2     people: ko.observableArray([
3         { name: 'Rod', age: 123 },
4         { name: 'Jane', age: 125 },
5     ])        
6 };
7         
8 ko.applyBindings(viewModel);
复制代码

整合underscore模板引擎与knockout.js

复制代码
 1    // 可以单独放在一个js文件中
 2     ko.underscoreTemplateEngine = function () { }
 3     ko.underscoreTemplateEngine.prototype = ko.utils.extend(new ko.templateEngine(), {
 4         renderTemplateSource: function (templateSource, bindingContext, options) {
 5             // 预编译和缓存效率的模板
 6             var precompiled = templateSource['data']('precompiled');
 7             if (!precompiled) {
 8                 precompiled = _.template("<% with($data) { %> " + templateSource.text() + " <% } %>");
 9                 templateSource['data']('precompiled', precompiled);
10             }
11             // 运行模板并解析成 DOM elements
12             var renderedMarkup = precompiled(bindingContext).replace(/\s+/g, " ");
13             return ko.utils.parseHtmlFragment(renderedMarkup);
14         },
15         createJavaScriptEvaluatorBlock: function(script) {
16             return "<%= " + script + " %>";
17         }
18     });
19     ko.setTemplateEngine(new ko.underscoreTemplateEngine());
复制代码

 

在线示例:http://jsfiddle.net/6pStz/

官方说明:http://knockoutjs.com/documentation/template-binding.html

这篇关于knockout.js模板绑定之利用Underscore.js模板引擎示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/291048

相关文章

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

Python利用PySpark和Kafka实现流处理引擎构建指南

《Python利用PySpark和Kafka实现流处理引擎构建指南》本文将深入解剖基于Python的实时处理黄金组合:Kafka(分布式消息队列)与PySpark(分布式计算引擎)的化学反应,并构建一... 目录引言:数据洪流时代的生存法则第一章 Kafka:数据世界的中央神经系统消息引擎核心设计哲学高吞吐

Java调用Python脚本实现HelloWorld的示例详解

《Java调用Python脚本实现HelloWorld的示例详解》作为程序员,我们经常会遇到需要在Java项目中调用Python脚本的场景,下面我们来看看如何从基础到进阶,一步步实现Java与Pyth... 目录一、环境准备二、基础调用:使用 Runtime.exec()2.1 实现步骤2.2 代码解析三、

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

MyBatis-Plus 与 Spring Boot 集成原理实战示例

《MyBatis-Plus与SpringBoot集成原理实战示例》MyBatis-Plus通过自动配置与核心组件集成SpringBoot实现零配置,提供分页、逻辑删除等插件化功能,增强MyBa... 目录 一、MyBATis-Plus 简介 二、集成方式(Spring Boot)1. 引入依赖 三、核心机制

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

springboot整合mqtt的步骤示例详解

《springboot整合mqtt的步骤示例详解》MQTT(MessageQueuingTelemetryTransport)是一种轻量级的消息传输协议,适用于物联网设备之间的通信,本文介绍Sprin... 目录1、引入依赖包2、yml配置3、创建配置4、自定义注解6、使用示例使用场景:mqtt可用于消息发

Go中select多路复用的实现示例

《Go中select多路复用的实现示例》Go的select用于多通道通信,实现多路复用,支持随机选择、超时控制及非阻塞操作,建议合理使用以避免协程泄漏和死循环,感兴趣的可以了解一下... 目录一、什么是select基本语法:二、select 使用示例示例1:监听多个通道输入三、select的特性四、使用se

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Python中的sort()和sorted()用法示例解析

《Python中的sort()和sorted()用法示例解析》本文给大家介绍Python中list.sort()和sorted()的使用区别,详细介绍其参数功能及Timsort排序算法特性,涵盖自适应... 目录一、list.sort()参数说明常用内置函数基本用法示例自定义函数示例lambda表达式示例o