- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当我使用部分 Jade 模板更新 div 内容时遇到问题。第一个删除用户的 ajax 调用工作正常,div 内容已更新,但是当我再次单击删除其他用户时,不会调用 ajax 操作。我看不出问题出在哪里。
这是我的代码
view/layout.jade
doctype html
html
head
title= title
link(rel='stylesheet', href='/stylesheets/style.css')
body
.container
block content
block footer
script(type='text/javascript' src='/javascripts/jquery.min.js')
script(type='text/javascript' src='/javascripts/functions.js')
view/index.jade
extends layout
block content
include menu.jade
#users_list
include users.jade
view/users.jade
table
thead
tr
th Id
th Name
th Description
th(colspan='2') Actions
tbody
if(users)
each user in users
tr
td #{user.id}
td
a(id=user.id href='#') #{user.name}
td
a(id=user.id href='#') #{user.description}
td
a(class='user_edit' id=user.id href='#' )
img(id=user.id src="images/edit.png")
td
a(class='user_delete' id=user.id href='#')
img(id=user.name src="images/trash.png")
routes/index.js
router.get('/deleteUser/:userid', function (req, res) {
UserModel.deleteUser({userid: req.params.userid}, function(error, data){
res.render('users', {
users : data
});
});
});
javascripts/functions.js
$(document).ready(function(){
//others functions and variables here!!!!!
$('.user_delete').on('click', function(e) {
e.preventDefault();
var userid = $(this).attr('id');
$.ajax({
method: 'GET',
url: baseurl + 'deleteUser/'+userid,
dataType: 'html',
success: function(data){
$('#users_list').html(data);
},
});
});
}
谢谢
最佳答案
原因是您将事件处理程序绑定(bind)到网页中已呈现的元素。当您单击删除并触发事件处理程序时,所有这些元素都会从页面中删除并替换为新内容,位于:
success: function(data){
$('#users_list').html(data);
},
最简单的解决方案是将事件处理程序绑定(bind)到您知道仍会出现在页面上的元素,并使用 on
的 selector
参数来过滤您想要绑定(bind)的元素。该事件处理程序将绑定(bind)到您永远不会从页面中删除的父元素。当您单击删除链接时,事件将冒泡到该元素,并且由于它与选择器匹配,因此将触发该事件。例如:
$('.container').on('click', '.user_delete', function(e) {
// as before...
}
作为一个额外的好处,这在浏览器中可能会稍微提高性能,因为您只将一个事件处理程序绑定(bind)到一个元素,而不是许多(我不太确定最近版本的 jQuery 中的这一点,但我认为它仍然成立)。
也就是说,您绝对不希望在 GET
请求中执行破坏性操作。这是一种肯定会破坏数据的方式。 GET
用于获取数据,并且对于同一请求始终获取相同的数据。为此使用 POST
请求,或者更好的是使用 DELETE
请求。
关于node.js - ajax调用更新jade部分模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34162977/
我想设计两个代理 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
我是一名优秀的程序员,十分优秀!