ajax调用更新玉局部模板
ajax call to update jade partial template
我在使用部分 jade 模板更新 div 内容时遇到问题。第一个删除用户的 ajax 调用工作正常并且 div 内容已更新,但是当我再次单击以删除其他用户时,不会调用 ajax 操作。我看不出问题出在哪里。
这是我的代码
view/layout.玉
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.玉
extends layout
block content
include menu.jade
#users_list
include users.jade
view/users.玉
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);
},
});
});
}
谢谢
原因是您将事件处理程序绑定到网页中已呈现的元素。当您单击删除并触发事件处理程序时,所有这些元素都会从页面中删除并替换为新内容,in:
success: function(data){
$('#users_list').html(data);
},
最简单的解决方案是将事件处理程序绑定到您知道仍将出现在页面上的元素,并使用 on
的 selector
参数来过滤您希望过滤的元素绑定到。此事件处理程序将绑定到您永远不会从页面中删除的父元素。当您单击删除 link 时,事件将冒泡到该元素,并且由于它与选择器匹配,事件将触发。例如:
$('.container').on('click', '.user_delete', function(e) {
// as before...
}
作为一个额外的好处,这在浏览器中的性能可能会稍微好一些,因为您只将一个事件处理程序绑定到一个元素,而不是多个元素(在 [=28= 的最新版本中我不太确定这一点) ],但我认为它仍然成立)。
也就是说,您绝对不想在GET
请求中进行破坏性操作。这是破坏数据的可靠方法。 GET
是用来获取数据的,并且总是为相同的请求获取相同的数据。为此使用 POST
请求,或者更好的是 DELETE
请求。
我在使用部分 jade 模板更新 div 内容时遇到问题。第一个删除用户的 ajax 调用工作正常并且 div 内容已更新,但是当我再次单击以删除其他用户时,不会调用 ajax 操作。我看不出问题出在哪里。
这是我的代码
view/layout.玉
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.玉
extends layout
block content
include menu.jade
#users_list
include users.jade
view/users.玉
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);
},
});
});
}
谢谢
原因是您将事件处理程序绑定到网页中已呈现的元素。当您单击删除并触发事件处理程序时,所有这些元素都会从页面中删除并替换为新内容,in:
success: function(data){
$('#users_list').html(data);
},
最简单的解决方案是将事件处理程序绑定到您知道仍将出现在页面上的元素,并使用 on
的 selector
参数来过滤您希望过滤的元素绑定到。此事件处理程序将绑定到您永远不会从页面中删除的父元素。当您单击删除 link 时,事件将冒泡到该元素,并且由于它与选择器匹配,事件将触发。例如:
$('.container').on('click', '.user_delete', function(e) {
// as before...
}
作为一个额外的好处,这在浏览器中的性能可能会稍微好一些,因为您只将一个事件处理程序绑定到一个元素,而不是多个元素(在 [=28= 的最新版本中我不太确定这一点) ],但我认为它仍然成立)。
也就是说,您绝对不想在GET
请求中进行破坏性操作。这是破坏数据的可靠方法。 GET
是用来获取数据的,并且总是为相同的请求获取相同的数据。为此使用 POST
请求,或者更好的是 DELETE
请求。