- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在 Node.js 之上使用 Express 和 Jade 来构建网络应用程序。我有一个 Express 路由,它从数据库中提取单词列表并将该列表作为数组对象发送到 Jade 以进行渲染。我想呈现我的 Jade 页面,以便在客户端单击每个单词时,将向服务器发送回一条不同的消息。
到目前为止,我的代码看起来像这样......
./routes/show_words_to_user.js:
exports.render_page = function(req, res){
DBClient.query('SELECT Word FROM Words;', function(err, result){
res.render('PageTitle',{WordList:result,UserData:UserObj});
});
};
./views/words.jade:
ul
each word in WordList
li= word
./routes/update_preference.js(期望收到来自客户端的消息):
exports.update_word = function(req, res){
DBClient.query('UPDATE Words SET UserLiked = 1 WHERE Word=($1) and UserId=($2)',
[ClickedWord,UserId],function(err, result){
res.send('Your word was updated.');
};
};
我需要在我的 Jade 列表中呈现的每个词都充当一个超链接,该链接将向服务器发送一条消息,其中包含 1) 单击的词的名称和 2) 服务器最初传递的用户 ID给 Jade 。
我的第一个想法是将每个列表项呈现为超链接,并使用 jQuery 将响应函数绑定(bind)到每个项目。然而,当我在客户端使用 jQuery 时,我无法为列表中的每个项目指定不同的函数。
我的第二个想法是执行内联 JavaScript 并设置 onclick= 一些我可以将列表项的文本传递给的函数,如下所示:
ul
each word in WordList
a(href='#',onclick='js_that_sends_word_to_update_preference(\'' + word + '\')')= word
这也有不良行为,因为每次我单击链接时页面都会跳到顶部。我以为我可以阻止它,但我无法为超链接调用“e.preventdefault”函数,因为我将一个字符串而不是一个事件传递给 onclick 函数。
我觉得我正在以完全错误的方式处理这件事。在 Jade 中可能有一个干净的方法来呈现迭代函数,但它正在逃避我。
最佳答案
所以您的问题实际上与 Node 或 Jade 无关,而是与您要生成的 HTML 和/或 JavaScript 有关?
一个简单的方法就是普通链接,就像您最初考虑的那样:
each word in WordList
a(href='/update_preference?clicked_word=' + encodeURIComponent(word), class='contact_server')= word
(我希望 Jade 语法没问题,我对它只有很少的经验)
关于javascript - 如何在 Jade 中为每个项目呈现一个具有不同 javascript 函数的列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23178587/
我想设计两个代理 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
我是一名优秀的程序员,十分优秀!