Javascript 在两次 HTML 注入(inject)后停止工作

标签 javascript jquery ajax django

我正在为我的站点创建一个聊天功能。它在左侧有对话,在右侧有用户列表。单击用户的 div 时,他们的 ID 将发送到 Django 后端,返回完整的 HTML,我调用 $('html').html('') 然后调用 $ ('html').html(data') 其中 data 是由 Django 呈现的完整返回 HTML。

当我点击一次用户时,整个页面都会刷新,我能够按预期执行所有与 JS 相关的事情。当我再次重新加载页面时,HTML 会重新加载返回的 HTML,但 JS 功能完全停止。当我检查开发人员工具中的元素时,JS 文件都在那里并加载到源选项卡中。

JavaScript 看起来像这样:

$(document).ready(function(){

    console.log("******LOAD*********")
    var d = $('div.profile-detail');
    d.scrollTop(d.prop("scrollHeight"));

    $('div.message-text').click(function(e){
        var id = $(this).attr('id');

        $.ajax({
        url: '#',
        method: 'GET',
        data: {'id': id,
                'task': 'get_messages'},
        dataType: 'html',
        success: function(data){
            $('html').html('');
            $('html').html(data);
            $('div.section-img').attr('id', id)
        },
        error: function(){
            console.log("Oh no!");
        }
        })

    })


    $('#message-text').keypress(function(e){
        if(e.which == 13 && !e.shiftKey){
            e.preventDefault();
            $.ajax({
                url: '#',
                method: 'GET',
                data: {'message': $('#message-text').val(),
                        'task': 'post-message',
                        'id': $('div.section-img').attr('id')
                },
                success: function(){
                    $('div.profile-section4').before(
                        '<div class="profile-section2">' +
                        '<p><span class="date-span">'+ new Date().toLocaleString() +'</span><br/><br/>' +
                            $('#message-text').val() +
                        '</p>'
                    ),
                    $('#message-text').val('')
                    d.scrollTop(d.prop("scrollHeight"));
                },
                error: function(){
                    console.log("failure");
                }
            })
        }

    });

})

我对 Django 的看法是这样的:

def view_messages(request):
    messages = Message.objects.filter(message_to=request.user, job_id=None).distinct('message_from')
    contact_user_ids = messages.values_list('message_from', flat=True).distinct()

    contacts = User.objects.filter(id__in=contact_user_ids)

    messages = Message.objects.filter(
        Q(message_to=request.user) & Q(message_from_id=contact_user_ids[0]) & Q(job_id=None) | Q(
            message_to=contact_user_ids[0]) & Q(
            message_from_id=request.user) & Q(job_id=None)).order_by('time_date')

    for message in messages:
        if message.message_from == request.user:
            message.sender = True
    try:
        current_chat_user = User.objects.get(id=contact_user_ids[0])
    except:
        current_chat_user = User.objects.get(id=int(request.GET['id']))

    if request.is_ajax():
        if request.method == 'GET':
            if request.GET['task'] == 'get_messages':
                messages = Message.objects.filter(
                    Q(message_to=request.user) & Q(message_from_id=int(request.GET['id'])) & Q(job_id=None) | Q(
                        message_to=int(request.GET['id'])) & Q(
                        message_from_id=request.user) & Q(job_id=None)).order_by('time_date')

                current_chat_user = User.objects.get(id=request.GET['id'])
            else:
                m = Message(message_from=request.user, message_to_id=int(request.GET['id']), message=request.GET['message'])
                m.save()

    return render(request, 'freelancestudent/general/messages.html', {'messages': messages,
                                                                      'messages_from': contacts,
                                                                      'current_chat_user': current_chat_user})

Here是初始页面加载和第一个 AJAX 请求之间的 HTML 的 DiffCheck。那么here是第一个 AJAX 请求和停止工作之前的最后一个请求之间的 DiffCheck。您会注意到第一个请求和第二个请求之间没有任何变化,但由于某种原因停止工作。为什么?

最佳答案

您使用的是旧式 jQuery 事件 Hook ,它们在页面就绪时进行评估,并引用特定的 DOM 元素。但是这些 DOM 元素会被您的重新加载所取代,因此该事件不再绑定(bind)到任何东西。

相反,您应该使用新型委托(delegate)事件:

$('html').on('click', 'div.message-text', function(e) ...

关于Javascript 在两次 HTML 注入(inject)后停止工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35130170/

相关文章:

javascript - 设置继承自prototype的属性值,为什么prototype值没有改变?

jquery - bootstrap-datepicker 没有被 requirejs 填充

javascript - 为什么我无法使用 Ajax 访问该变量的属性?

PHP 和 jQuery 与 MySQL

javascript - 如果我在屏幕上来回移动,为什么 useState 的状态会突然恢复为 false?

javascript - 如何从 Asp.Net(selectedIndexChange) 中的用户获取 DropDownList 选择的值

javascript - 从 Canvas 中删除/取消绑定(bind) d3 缩放

javascript - 如何在 bootstrap 下拉菜单中启用向上和向下箭头键

javascript - 我的数组输出中的 `#` 来自哪里?

php - 为什么要提交这个表单?