- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个使用 Express 和 Jade(现在是 Pug)的 nodejs 应用程序。我想预编译 jade 模板以获得更好的性能。我已经能够使用 jade --client
将 jade 转换为 javascript,将所有 .jade 文件编译为相应的 .js。
如何在我的应用程序中使用这些 js 文件?我对 nodejs/express 没有太多经验,但我认为它必须改变渲染引擎?我已经阅读了说明使用 runtime.js
的官方文档,但我找不到任何关于如何使用它的文档。
最佳答案
Jade(现在是 Pug)是一个很棒的模板引擎,但是 View 的编译会消耗大量资源。 Jade 是慢。当然,您可以在生产环境中使用 express 的“缓存 View ”功能来缓存编译后的 View ,但是编译后的 View 存储在内存中,会消耗大量资源。感谢 Jade,我开发的最新的 express 应用程序在 800 多毫秒内响应了第一个请求,所以由于我不想更改模板引擎,我和你一样,决定在我的开发中编译 Jade View 环境并部署这些文件而不是原始 View 。
为了使用由名为template
的函数组成的.js
文件的编译 View ,您需要使用jade runtime .运行时生成属性值并执行其他操作,例如转义 值。 template
函数接受一个用于动态数据 的参数。
由于这些函数是为客户端编译的,编译后的 View 依赖于全局 jade 运行时(即 window.jade
)。在 node.js 中,您可以填充 GLOBAL
对象,即 GLOBAL.jade = require('jade/lib/runtime')
但这不是一个好主意。我决定修改编译后的函数:
module.exports
require
编译 View (.js
文件)。 以下代码片段在 .gulpfile
中使用了 gulp
、gulp-jade
和 gulp-replace
Node 模块>:
gulp.task('compile-jade', () => {
// get all the jade files and compile them for client
return gulp.src([
'../views/**/*.jade'
]).pipe(jade({
client: true
}))
// replace the function definition
.pipe(replace('function template(locals)', 'module.exports = function(locals, jade)'))
.pipe(gulp.dest('../views_js') );
});
现在我们已经更改了函数声明,我们可以加载编译后的文件(.js
文件)而不是 .jade
文件。但是还有一个问题。没有用于使用这些文件的预制模板引擎(据我所知)。所以我们需要定义一个新的引擎。这很简单:
let jade = require('jade/lib/runtime');
app.engine('js', function (filePath, options, callback) { // define the template engine
let data = require(filePath)(options, jade);
callback(null, data);
});
现在我们可以在 express 中更改 View 相关的设置:
app.set('view engine', 'js');
app.set('views', path.join(__dirname, 'views_js'));
现在响应应用程序启动时的第一个请求对我来说需要 7 毫秒。请注意,require
会为不存在的文件抛出错误,因此您可以考虑使用 try/catch
或 promises 来处理可能的异常。
关于node.js - 如何在 Node.js Express 应用程序中呈现预编译的 Jade (Pug) 模板?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16183126/
我想设计两个代理 Agent1 在不同的时间向 Agent2 发送两个消息值。 Agent2 然后根据接收到的值执行操作。 使用 Jade,我尝试编写以下内容: -Agent1 有两个 addBeha
我只是 JADE 的初学者。我想知道如何创建主容器以外的容器并将多个代理添加到其中。完整的创建代码将不胜感激。 谢谢! 最佳答案 如 Tafadzwa Chikudo 回答中所述,启动容器的常用方法是
我正在尝试使用 Jade block ,但我的内容未显示。这是我的 index.jade: //index.jade extends ../includes/layout block main-con
我不知道 Jade 内部是如何工作的,但我猜它会编译每个模板文件一次,然后为每个 HTTP 请求使用编译和缓存的版本。 当我运行我的 Express 应用程序并对我的 *.jade 文件进行更改时,更
我正在制作一个基于 Express 的 Web 应用程序,每次有人访问这个 jade 文件时,我都会收到以下错误: Warning: missing space before text for lin
我正在向 Jade 模板传递一些数据,这些数据采用 JSON 形式,因此例如这里我输出 Jade 模板中所有团队的名称: p Teams: br -for(var i = 0; i < tou
我的 jade.js 文件中有以下内容 'use strict'; var config = require('../config'); module.exports = { dist: {
是否可以从非 JADE 应用程序(用 Java 或 C/C++ 编写)向 JADE 代理/平台发送消息(并从中接收消息)?是否可以通过某种方式向包含符合 FIPA 的 ACL 消息的平台发送 HTTP
我目前正在使用 gulp-jade,我正在努力研究如何在我的 gulpfile.js 中设置 Jade include。(为了澄清,我在这里指的是 http://jade-lang.com/refer
我有一个与 mongodb 集成的 Nodejs 项目。在这里,我创建了一个 jade 文件,其中有从数据库中获取的学生列表。每个学生记录都有一个编辑按钮。因此,当用户单击编辑按钮时,它需要将用户重定
我正在慢慢学习nodejs、express、jade。这就是我想要完成的基本任务: ul.nav - var obj = { 'home':'i.icon-home.icon-white Home
在jade模板引擎中: - 我可以做一个每个循环来包含文件吗?例如 each val in ['file1', 'file2', 'file3'] include val 最佳答案 “您正在
我有一个 View ,其中返回的 MIME 类型各不相同。如何设置标题部分的内容类型? 这是我想做的 !!! html head title #{site.title} - #{site.
框架:node.js/express.js/Jade 问题:在生产环境中,当一个 jade 文件被 express 渲染时,jade 缓存了它,所以 future 的渲染速度会更快。 当我启动 nod
我在 node.js 中有一个网站;要创建一个页面,比如说 mypage 我注意到我需要同时创建一个 layout.jade 和 mypage.jade 文件。如果我将代码放在 mypage.jade
我想将我的数据对象传递给 Jade 文件,但这是不可能的 我的 jade-loader : { test: /\.jade$/, loader: "jade", query: {
约曼/咕噜/ Jade 我的文件夹结构如下: App/ App/jade/user.jade /user.edit.jade /user.details.jade 当
所以我正在做这个项目,我正在使用 gulp。我需要它能够编译我编写的 jade(在 _jadefiles 文件夹中)并将它们作为 .html 输出到我项目的 _includes 文件夹中。 我目前正在
我正在使用 Jade/Express 构建的网站工作了几个星期。我最近为网站组织了图像文件夹,因此所有图像都分布在几个文件夹之间,以便于使用和分类。 为了更轻松地更改图像(和其他此类文件)的层次结构,
是的,我对问这样一个新手问题感到内疚。 app.get('/skumanagement/:id', function (req, res){ var options = req.params
我是一名优秀的程序员,十分优秀!