javascript - 如何获得 XMLHttpRequest 的响应?

标签 javascript xmlhttprequest

我想知道如何使用 XMLHttpRequest 加载远程 URL 的内容并将访问站点的 HTML 存储在 JS 变量中。

说,如果我想加载和 alert() http://foo.com/bar.php 的 HTML ,我该怎么做?

最佳答案

您可以通过 XMLHttpRequest.responseText 获取在 XMLHttpRequest.onreadystatechangeXMLHttpRequest.readyState 等于 XMLHttpRequest.DONE 时。

这是一个示例(与 IE6/7 不兼容)。

var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function() {
    if (xhr.readyState == XMLHttpRequest.DONE) {
        alert(xhr.responseText);
    }
}
xhr.open('GET', 'http://example.com', true);
xhr.send(null);

为了更好的跨浏览器兼容性,不仅是与 IE6/7,还包括一些特定于浏览器的内存泄漏或错误,以及在触发 ajaxical 请求时减少冗长,您可以使用 jQuery .

$.get('http://example.com', function(responseText) {
    alert(responseText);
});

请注意,您必须使用 Same origin policy for JavaScript不在本地主机上运行时考虑。您可能需要考虑在您的域中创建一个代理脚本。

关于javascript - 如何获得 XMLHttpRequest 的响应?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3038901/

相关文章:

javascript - 如何将CSS应用于没有类的div?

javascript - fetch、ajax 和 xhr 之间的区别

javascript - 绕过 Google Drive 链接的病毒扫描并获取确认 ID

javascript - 如何使用 jQuery 异步上传文件?

javascript - 为什么这两个对原型(prototype)的引用返回不同的值

javascript - 如何在关注父元素时保持 `textarea` 展开?

javascript - php 使用 ajax 生成 html 表以应用用户操作,如删除、更新和编辑

javascript - JS : Getting the subsequent k items 中的初学者 Firebase

testing - testcafe 的 RequestLogger 中的方法是否可以有多个键值

javascript - API 端点资源上没有 Access-Control-Allow-Origin header