Ajax提供程序返回太多Asp.Net html

Ajax provider returns too much html Asp.Net

本文关键字:Asp Net html 太多 返回 程序 Ajax      更新时间:2023-09-26

我正在尝试对Asp.net中的页面进行部分更新。我通过ajax调用我的.aspx页面来构建我需要附加到页面上的特定位置的内容,以前这对我有用。

我目前的问题是,我得到了完整的html,而不仅仅是元素,我不知道我以前做对了什么。

                var dataObj = { 'includeInactive': includeInactive, 'MasterPersonId': masterId, 'sChosenSSN': chosenSSN };
        $.ajax({
            url: 'clientside/providers/MergeJournalProviders/---ShowSomeDuplicateCivilRegistrationNumbers.aspx',
            dataType: 'html',
            data: dataObj,
            cache: false,
            async: true,
            beforeSend: function (xhr) {
            },
            success: function (result) {
                if (result != "" && result != undefined) {
                    //var htmlToAppend = $(result).find("#DuplicatePeople div").html();
                    //her vælger jeg gruppen(group) der skal opdateres
                    var oldDiv = $('#DupPpl');
                    var newDiv = jQuery(result).find('#DupPpl').html()
                    oldDiv.replaceWith(newDiv);
                    //$('#DupPpl').empty();
                    //$('#DupPpl').html(jQuery(result).find('#DuplicatePeople').html());
                    //$('#DupPpl').remove();
                    //$('#DupPpl').append(result);
                    //$('#DupPpl').append(result);

                }
            }
        });

如果你的结果有aspx文件中的所有html和一个id为"DupPpl"的元素存在于html中,你可以使用jquery contents:

试题:

var oldDiv = $('#DupPpl');
var newDiv = $(result).contents().find('#DupPpl').html();
oldDiv.replaceWith(newDiv);

使用相同的代码获取其他元素:

$(result).contents().find('YOUR_ELEMENT_ID').html();

这是使用更新面板的不幸后果。它们的简单性带来了更高的成本。结果是,不仅面板的内容会被发回,所有视图状态和HTML标头等也会被发回。使用jQuery、页面方法和web服务可以实现更有效的部分回发。查看这篇文章:http://msdn.microsoft.com/en-us/library/0b283bse%28v=vs.71%29.aspx