- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Jade/Express 构建的网站工作了几个星期。我最近为网站组织了图像文件夹,因此所有图像都分布在几个文件夹之间,以便于使用和分类。
为了更轻松地更改图像(和其他此类文件)的层次结构,我编写了一个脚本,其中包含一些文件路径的全局变量。现在我一直在尝试让脚本运行,以便我可以调用 jade 模板中的函数来自动使用这些全局变量。
例如。图像现在被分类到几个文件夹中:
文件层次结构
img/
glyphs/
interactivity/
buttons/
...
在我的路径管理器脚本中,我创建了几个函数,包括:
在:path-manager.js
images_root_path = "/img/";
glyph_path = images_root_path + "glyphs/";
function getGlyph(color, name) {
return glyph_path + color + "/" + name;
}
我尝试了几种方法让脚本在模板之前执行。这是其中一种尝试:
在page.jade
include ../../../public/js/lib/path-manager.js
=NamespacePathManager();
理论上,上面应该包含 js,然后我执行下面的命名空间以使函数可用,但那不起作用。
这是 Jade 模板的一部分,我想在其中使用该函数:
在page.jade脚本包含之后
span.challenge-time
img(src=getGlyph("black","stopwatch.png"), style="margin-right:5px;")
上面的例子应该返回:"/img/glyphs/black/stopwatch.png"
问题是,我认为,我试图在服务器端提供给 jade 模板的脚本在呈现 jade 模板之前 没有被执行。我为使它正常工作而尝试做的所有事情总是会导致错误,提示服务器无法识别函数 getGlyph 或者当我开始使用命名空间函数时,NamespacePathManager
总结:我希望在将 jade 模板呈现到网页之前执行一个 javascript 文件,这样我就可以在呈现 jade 模板时调用服务器上该 javascript 中的函数和变量。我的问题是我尝试过的所有方法都无法在呈现 Jade 之前执行 javascript。
更新我发现的一种解决方法是将 javascript 直接放入页面上的无缓冲代码中,包括一 block Jade 。这不是我一直在寻找的优雅解决方案,但它现在有效
- some code
- more code
这段代码是内联执行的。缺点是我必须手动将它包含在每个页面上 - 而不是只包含一次并让功能随处可用。
最佳答案
您可以在 Express 中注册helper 方法,然后可以在 View 中访问这些方法。
因此在您的情况下,path-manager.js 可以是您注册的帮助程序文件,并且包含:
var images_root_path = "/img/";
var glyph_path = images_root_path + "glyphs/";
exports.helpers = {
getGlyph: function (color, name) {
return glyph_path + color + "/" + name;
}
// Other helper methods here..
};
然后在设置 express server 的时候,注册 helper
var app = express.createServer();
// app.configure here...
// app.use ...
app.helpers(require('./path-manager.js').helpers);
// Routes set up here ..
最后,您可以像这样从 Jade View 调用辅助方法:
span.challenge-time
img(src='#{getGlyph("black","stopwatch.png")}', style='margin-right:5px;')
在 DailyJS http://dailyjs.com/2011/01/03/node-tutorial-8/ 上有一篇关于这个主题的好文章
关于javascript - Jade 编译前如何在 Jade 模板中包含 Javascript 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10420990/
我想设计两个代理 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
我是一名优秀的程序员,十分优秀!