gpt4 book ai didi

javascript - 使用 AJAX 获取特定的 DOM 元素(使用 Javascript,而不是 jQuery)

转载 作者:行者123 更新时间:2023-11-29 10:20:22 26 4
gpt4 key购买 nike

如何使用 AJAX(在纯 JavaScript 中,不是 jQuery)获取页面(同一域)并仅显示特定的 DOM 元素? (比如id为“bodyContent”的DOM元素)。

我正在使用 MediaWiki 1.18,所以我的方法必须稍微不那么传统(我知道可以为 MediaWiki 启用一个 jQuery 版本,但我无权这样做,所以我需要查看在其他选项)。如果代码困惑,我深表歉意,但我需要以这种方式构建它是有原因的。我最感兴趣的是看看可以用 Javascript 做什么。

这是 HTML 代码:

<div class="mediaWiki-AJAX"><a href="http://www.domain.com/whatever"></a></div>

这是我目前拥有的 Javascript:

var AJAXs = document.getElementsByClassName('mediaWiki-AJAX');
if (AJAXs.length > 0) {
for (var i = AJAXs.length - 1; i >= 0; i--) {
var URL = AJAXs[i].getElementsByTagName('a')[0].href;
xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
AJAXs[i].innerHTML = xmlhttp.responseText;
}
}
xmlhttp.open('GET',URL,true);
xmlhttp.send();
}
}


编辑:

感谢回答lbstr给了,我能够想出以下内容,这行得通!您会注意到我添加了额外的步骤来删除任何我不想要的元素。无论出于何种原因,getElementById() 对 responseText 不起作用,但 getElementsByClassName() 起作用。我想这是因为在运行 AJAX 调用之前维基页面上已经存在“bodyContent”的 ID。

//This function is necessary to read the response text correctly.
function outerHTML(node){
// if IE, Chrome take the internal method otherwise build one
return node.outerHTML || (
function(n){
var div = document.createElement('div'), h;
div.appendChild( n.cloneNode(true) );
h = div.innerHTML;
div = null;
return h;
})(node);
}

// This code deals with populating the AJAX divs within a wiki page.
var AJAXs = document.getElementsByClassName('mediaWiki-AJAX');
if (AJAXs.length > 0) {
for (var i = AJAXs.length - 1; i >= 0; i--) {
(function(index){
var URL = AJAXs[index].getElementsByTagName('a')[0].href;
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
var tempDiv = document.createElement('div');
tempDiv.innerHTML = xmlhttp.responseText;
var AJAXContent = tempDiv.getElementsByClassName('mw-content-ltr')[0];

//Remove unnecessary "fixed" items to avoid clutter.
var hiddenItems = AJAXContent.getElementsByClassName('hidden-item');
if (hiddenItems.length > 0) {
for (var j = hiddenItems.length - 1; j >= 0; j--) {
AJAXContent.removeChild(hiddenItems[j]);
}
}
var protectedItems = AJAXContent.getElementsByClassName('protected-item');
if (protectedItems.length > 0) {
for (var j = protectedItems.length - 1; j >= 0; j--) {
AJAXContent.removeChild(protectedItems[j]);
}
}

//Insert the AJAX content and rerun Javascript on it.
if (AJAXContent !== null && AJAXContent !== undefined) {
AJAXs[index].innerHTML = outerHTML(AJAXContent);
assign_Popup_Functions(AJAXs[index]);
fix_External_Links(AJAXs[index]);
assign_iFrame_Functions(AJAXs[index]);
}
}
}
xmlhttp.open('GET',URL,true);
xmlhttp.send();
})(i);
}
}

最佳答案

在你的回调中你似乎可以这样做:

var temp = document.createElement("div");
temp.innerHTML = xmlhttp.responseText;
var bodyContent = temp.getElementById("bodyContent");
if (bodyContent !== null && bodyContent !== undefined) {
AJAXs[i].innerHTML = outerHTML(bodyContent);
}

给定来自 this SO post 的 outerHTML 函数:

function outerHTML(node){
// if IE, Chrome take the internal method otherwise build one
return node.outerHTML || (
function(n){
var div = document.createElement('div'), h;
div.appendChild( n.cloneNode(true) );
h = div.innerHTML;
div = null;
return h;
})(node);
}

请记住,如果您对多个 AJAXs 容器执行此操作,您最终可能会得到多个具有相同 ID (bodyContent) 的项目。确保你想出一些方法来避免这种情况。也许你想要 innerHTML?

编辑:

我还忘记指出您的设置会出现的错误。由于您的回调将在循环完成之后到达,i 的值将始终为0,因此您不会更新正确的容器。你需要做这样的事情:

for (var i = AJAXs.length - 1; i >= 0; i--) {
(function(index){
var URL = AJAXs[index].getElementsByTagName('a')[0].href;
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
AJAXs[index].innerHTML = xmlhttp.responseText;
}
}
xmlhttp.open('GET',URL,true);
xmlhttp.send();
})(i);
}

关于javascript - 使用 AJAX 获取特定的 DOM 元素(使用 Javascript,而不是 jQuery),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13458501/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com