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

相关文章

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

QT6中绘制UI的两种方法详解与示例代码

《QT6中绘制UI的两种方法详解与示例代码》Qt6提供了两种主要的UI绘制技术:​​QML(QtMeta-ObjectLanguage)​​和​​C++Widgets​​,这两种技术各有优势,适用于不... 目录一、QML 技术详解1.1 QML 简介1.2 QML 的核心概念1.3 QML 示例:简单按钮

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

MyBatisX逆向工程的实现示例

《MyBatisX逆向工程的实现示例》本文主要介绍了MyBatisX逆向工程的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录逆向工程准备好数据库、表安装MyBATisX插件项目连接数据库引入依赖pom.XML生成实体类、

$在R语言中的作用示例小结

《$在R语言中的作用示例小结》在R语言中,$是一个非常重要的操作符,主要用于访问对象的成员或组件,它的用途非常广泛,不仅限于数据框(dataframe),还可以用于列表(list)、环境(enviro... 目录1. 访问数据框(data frame)中的列2. 访问列表(list)中的元素3. 访问jav

VSCode中配置node.js的实现示例

《VSCode中配置node.js的实现示例》本文主要介绍了VSCode中配置node.js的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一.node.js下载安装教程二.配置npm三.配置环境变量四.VSCode配置五.心得一.no

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格