首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Github上开源的10大Javascript模板引擎,助力前端开发

,那么今天就介绍10大开源模板引擎,依据不同的场景或者功能特性,可以选择不同的模板引擎应用到项目中去: 1....Template.js 5. Tempo 6. ECT 7. Dot Dom 8. Template7 9. Bunny 10....拥有接近 JavaScript 渲染极限的的性能 调试友好:语法、运行时错误日志精确到模板所在行;支持在模板文件上打断点(Webpack Loader) 支持 Express、Koa、Webpack 支持模板继承与子模板...Template.js JavaScript模板引擎,简单易用,支持webpack和fis。提供了一组模板语法,用户可以编写一个模板块。...具有出色的性能,模板缓存,自动重新加载已更改的模板模板中的CoffeeScript代码 https://github.com/baryshev/ect var ECT = require('ect

6.2K31

简单而强大的swig.js

本文作者:IMWeb json 原文出处:IMWeb社区 未经同意,禁止转载 swig的简单介绍 swig是JS模板引擎,它有如下特点: 根据路劲渲染页面 面向对象的模板继承,页面复用 动态页面...swig的标签 extends 使当前模板继承父模板,必须在文件最前 参数: file 父模板相对模板 root 的相对路径,将在后面介绍如何实现模板继承。...block 定义一个块,使之可以被继承的模板重写,或者重写父模板的同名块 参数: name 块的名字,必须以字母数字下划线开头 parent 将父模板中同名块注入当前块中 include 包含一个模板到当前位置...,这个模板将使用当前上下文 参数: file 包含模板相对模板 root 的相对路径 {% include "a.html" %} {% include "template.js..." %} //将引入的文件内容放到被引用的地方 raw 停止解析标记中任何内容,所有内容都将输出 参数: file 父模板相对模板 root 的相对路径 for 遍历对象和数组 参数:

1.4K90

简单而强大的swig.js

本文作者:IMWeb json 原文出处:IMWeb社区 未经同意,禁止转载 swig的简单介绍 swig是JS模板引擎,它有如下特点: 根据路劲渲染页面 面向对象的模板继承,页面复用 动态页面...swig的标签 extends 使当前模板继承父模板,必须在文件最前 参数: file 父模板相对模板 root 的相对路径,将在后面介绍如何实现模板继承。...block 定义一个块,使之可以被继承的模板重写,或者重写父模板的同名块 参数: name 块的名字,必须以字母数字下划线开头 parent 将父模板中同名块注入当前块中 include 包含一个模板到当前位置...,这个模板将使用当前上下文 参数: file 包含模板相对模板 root 的相对路径 {% include "a.html" %} {% include "template.js..." %} //将引入的文件内容放到被引用的地方 raw 停止解析标记中任何内容,所有内容都将输出 参数: file 父模板相对模板 root 的相对路径 for 遍历对象和数组 参数:

1.1K20

模板(下)——(类模板

模板 声明类模板模板的成员函数被认为是函数模板,也称为类属函数。...使用类模板 声明类模板之后创建模板类,一般格式如下: 类模板名对象表; 其中,类型实参表应与该类模板中的“类型形参表”相匹配。“对象表”是定义该模板类的一个或多个对象。...类模板作为函数参数 函数的形参类型可以是类模板或类模板的引用,对应的实参应该是该类模板实例化的模板类对象。同时,对于带有类模板参数的函数,这个函数必须是函数模板。...类模板作为友元函数的形参类型 在一个类模板中可以设计友元函数。友元函数的形参类型可以是类模板或类模板的引用,对应的实参应该是该类模板实例化的模板类对象。...同时,对于带有类模板参数的友元函数,这个友元函数必须是函数模板。 类模板与静态成员 从类模板实例化的每个模板类都有自己的类模板静态数据成员,该模板类的所有对象共有一个静态数据成员。

2.1K30

【c++】模板---函数模板模板

模板是泛型编程的基础 2.函数模板 2.1函数模板概念 函数模板代表了一个函数家族,该函数模板与类型无关,在使用时被参数化,根据实参类型产生函数的特定类型版本 2.2函数模板格式 template...一个非模板函数可以和一个同名的函数模板同时存在,而且该函数模板还可以被实例化为这个非模板函数 // 专门处理int的加法函数 int Add(int left, int right) { return...,编译器不需要特化 Add(1, 2); // 调用编译器特化的Add版本 } 对于非模板函数和同名函数模板,如果其他条件都相同,在调动时会优先调用非模板函数而不会从该模板产生出一个实例。...,不需要函数模板实例化 Add(1, 2.0); // 模板函数可以生成更加匹配的版本,编译器根据实参生成更加匹配的Add函数 } 模板函数不允许自动类型转换,但普通函数可以进行自动类型转换 3.类模板的定义格式...= 0; } 2.类模板的实例化 类模板实例化与函数模板实例化不同,类模板实例化需要在类模板名字后跟,然后将实例化的类型放在中即可,类模板名字不是真正的类,而实例化的结果才是真正的类 /

6210

模板(上)——(函数模板

模板概述 C++有两种模板机制:函数模板和类模板模板中的参数也称为类属参数。 模板模板类、对象和模板函数之间的关系: ?...函数模板 函数模板是对一组函数的描述,他不是一个真实的函数,编译系统并不产生任何执行代码。...当编译系统在程序中发现有与函数模板中相匹配的函数调用时,便产生一个重载函数,该重载函数的函数体与函数模板的函数体相同,该重载函数就是模板函数。...将数据类型形参实例化的参数称为模板实参,用模板实参实例化的函数就是模板函数。模板函数的生成就是将函数模板的类型形参实例化的过程。...函数模板本身可以用多种方式重载,还需要提供其他函数模板,指定不同参数的相同函数名。

1.5K20

c++之模板函数-模板

模板就是建立通用的模具,大大提高复用性。 c++的另一种编程思想是泛型编程,主要利用的就是模板。 c++提供两种模板机制:函数模板和类模板。...声明:template//typename可以替换成class 函数模板 函数模板的作用:建立一个通用函数,其函数返回值类型和形参类型可以不具体制定,用一个虚拟的类型来代表。...#include #include #include using namespace std; //模板函数 //声明一个模板,表明T是一个通用数据类型...& b) { T tmp = a; a = b; b = tmp; } int main() { int a = 1; int b = 2; //使用模板函数有两种方式...模板注意事项: 自动类型推导必须推导出一致的数据类型T才可以使用; 模板必须要确定出T的数据类型;

1.5K10

【C++】非类型模板参数、模板特化、模板的分离编译、模板总结

一、非类型模板参数 模板参数分类类型形参与非类型形参。 类型形参:出现在模板参数列表中,跟在class或者typename之类的参数类型名称。...非类型形参:就是用一个常量作为类(函数)模板的一个参数,在类(函数)模板中可将该参数当成常量来使用。...---- 二、模板特化 1.函数模板特化 通常情况下,使用模板可以实现一些与类型无关的代码,但对于一些特殊类型的可能会得到一些错误的结果 我们来以日期类为例子: class Date { public:...,直接写成函数也是可以的,因为函数模板支持重载 2.类模板特化 1.全特化 全特化即是将模板参数列表中所有的参数都确定化 类模板的全特化将模板参数列表中的所有参数我们都将其写出来: 如果此时的数据类型是我们自己定义的...此时在编译阶段中,就有了模板的实例化。 模板定义的位置显式实例化。这种方法不实用,不推荐使用 。

24821
领券