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);
},

最简单的解决方案是将事件处理程序绑定到您知道仍将出现在页面上的元素,并使用 onselector 参数来过滤您希望过滤的元素绑定到。此事件处理程序将绑定到您永远不会从页面中删除的父元素。当您单击删除 link 时,事件将冒泡到该元素,并且由于它与选择器匹配,事件将触发。例如:

$('.container').on('click', '.user_delete', function(e) {
    // as before...
}

作为一个额外的好处,这在浏览器中的性能可能会稍微好一些,因为您只将一个事件处理程序绑定到一个元素,而不是多个元素(在 [=28= 的最新版本中我不太确定这一点) ],但我认为它仍然成立)。

也就是说,您绝对不想GET请求中进行破坏性操作。这是破坏数据的可靠方法。 GET 是用来获取数据的,并且总是为相同的请求获取相同的数据。为此使用 POST 请求,或者更好的是 DELETE 请求。