- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为什么这段代码不起作用(调用 handleRequestStateChange 函数时)?:
function ajaxRequest(){
var xmlObj = new XMLHttpRequest();
xmlObj.open("GET","1.php",true);
xmlObj.onreadystatechange = handleRequestStateChange;
xmlObj.send(null);
}
var handleRequestStateChange = function(){
if(xmlObj.readyState == 4 && xmlObj.status==200){
alert("if loaded");
}
}
但是这个是(没有调用 handleRequestStateChange 函数):
function ajaxRequest(){
var xmlObj = new XMLHttpRequest();
xmlObj.open("GET","1.php",true);
xmlObj.onreadystatechange = function(){
if(xmlObj.readyState == 4 && xmlObj.status==200){
alert("if loaded");
}
}
xmlObj.send(null);}
最佳答案
在这种特殊情况下,问题只是在变量的范围内,在这种情况下,ajaxRequest
可以“看到”handleRequestStateChange
但是handleRequestStateChange
无法“看到”xmlObj
.在第二个例子中,匿名函数可以看到xmlObject
因为它在“内部”ajaxRequest
.
这个 stackoverflow 答案是一个不错的起点。 https://stackoverflow.com/a/500459/1480215
例如,删除 var
实际上修复了第一个代码(这不是个好主意)。
function ajaxRequest(){
xmlObj = new XMLHttpRequest(); //suddenly global scope
xmlObj.open("GET","1.php",true);
xmlObj.onreadystatechange = handleRequestStateChange;
xmlObj.send(null);
}
var handleRequestStateChange = function(){
if(xmlObj.readyState == 4 && xmlObj.status==200){
alert("if loaded");
}
}
下面的代码也可以工作
function ajaxRequest(){
var xmlObj = new XMLHttpRequest();
var handleRequestStateChange = function(){
if(xmlObj.readyState == 4 && xmlObj.status==200){
alert("if loaded");
}
}
xmlObj.open("GET","1.php",true);
xmlObj.onreadystatechange = handleRequestStateChange;
xmlObj.send(null);
//but not if var handleRequestStateChange is here
//due to https://stackoverflow.com/a/336868/1480215
}
为了完整起见,我还将包括下面应该有效的代码段
function ajaxRequest(){
var xmlObj = new XMLHttpRequest();
xmlObj.open("GET","fragments.htm",true);
xmlObj.onreadystatechange = handleRequestStateChange;
xmlObj.send(null);
function handleRequestStateChange(){ //this will work instead of var funcName=function(){}
if(xmlObj.readyState == 4 && xmlObj.status==200){
alert("if loaded");
}
}
}
如果我们严格来说 xmlHttpRequest
事件(或一般事件),那么也可以使用传递的事件参数。
function ajaxRequest(){
var xmlObj = new XMLHttpRequest();
xmlObj.open("GET","1.php",true);
xmlObj.onreadystatechange = handleRequestStateChange;
xmlObj.send(null);
}
var handleRequestStateChange=function(event){ //event handlers passes this, generally
var xmlObj=event.target || event.srcElement //for compatibility
//but just having XMLHttpRequest(), is not fully cross-platform anyway
if(xmlObj.readyState == 4 && xmlObj.status==200){
alert("if loaded");
}
}
展望 future ,我认为使用现有的小型 ajax 片段或库(如 http://www.openjs.com/scripts/jx/)可能是个好主意。 .甚至 jQuery 也有 RPC(包括 <script>
s 以包含来自其他域的脚本而没有 COR)
关于javascript - ajax onreadystatechange 函数未被调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23619709/
我的请求有以下代码: var req = new XMLHttpRequest(); req.onreadystatechange = function() { if (req.
请记住,我对 JavaScript 语法非常很陌生,所以请耐心等待。 我试图使用多个onreadystatechange作为 promise 来捕获我从express返回的内容,但每次我这样做时,它们
我有一个问题。我在我用来触发的外部 javascript (ajax) 中有一个删除函数,以便执行我的 PHP 文件中的删除查询。 我想知道的是 onreadystatechange 函数中应该有什么
我希望 AJAX 回调触发 myFucntion 中的 alert() 并显示“它有效”,如何在 ajaxResponse 中引用 myobject 对象? function myobject() {
好的...所以我的代码非常简单。唯一的问题是调用 onreadystatechange 的函数永远不会被执行。我发出警报以显示 readyState 和 xmlhttp 的状态,分别显示为 1 和 0
这里是 Angular 新手。我想知道是否可以使用 $http 服务在任何就绪的状态/状态 更改时调用函数,而不仅仅是在成功/失败。在代码方面,它将是与以下 JS 代码等效的 Angular 代码:
一个多小时以来,我一直在尝试调试我的代码,但没有成功。我意识到ajax的异步调用意味着我必须将回调函数与onreadystatechange事件结合使用。问题是,我在控制台中不断收到“Uncaught
由于某些原因,onreadystatechange 回调函数没有在异步模式下被调用。我在同步模式下测试了帖子并确认帖子本身工作正常(注释掉了我用来在同步模式下检查帖子的测试代码)。该问题同时出现在 s
我有一个包含 的 HTML 页面. 正在根据某些事件进行刷新(我可以看到 的内容正在更改,所以到目前为止一切正常)。 我想做的是添加一个 onreadystatechange到 这样我就可以在获取
我正在尝试执行一些 AJAX,并且需要知道为什么这段代码没有触发完成或错误警报。我在 Mozilla Firefox 20.0.1 请注意 这段代码是更新数据库(我有一个选择语句读取确切的记录来验证它
我在将函数的值返回到变量时遇到一些问题。它显然是“未定义的”。这显然是由于 JavaScript 的异步性造成的。但就我而言,我不知道如何通过“回调”或“ promise ”来规避它。请参阅下面的代码
我正在尝试克服 ajax 请求,但 Chrome 控制台向我显示以下消息:xml_http.onreadystatechange 不是一个函数 这是我的 JS 代码: function ajax_re
背景 我每 5 秒使用 XMLHttpRequest 发出一个请求我想在收到回复时打印我的名字。 为此,我使用 onreadystatechange这允许我在收到答案时定义回调函数。 问题 为了实现这
我有一个名为 urlExists 的函数,我在几个项目中使用它都没有问题。现在我在患者面板中,需要在调用函数 addEventListener 之前检查 js 文件是否存在: function url
xmlhttp.onreadystatechange=function() { 因此这表示 onreadystatechange,调用 function()。我可以将参数放在 function() 中
什么是 JavaScript 类型不匹配错误? 可能的原因是什么? 我无法包含所有代码,但这是出现错误的行。 xmlObject.onreadystatechange = null; 最佳答案 您收到
这个问题在这里已经有了答案: How do I return the response from an asynchronous call? (41 个回答) 关闭 7 年前。 我正在尝试从 onr
为什么这段代码不起作用(调用 handleRequestStateChange 函数时)?: function ajaxRequest(){ var xmlObj = new XMLHttpRequ
我正在尝试让 AJAX 请求生效;具体来说,我不想在控制台中记录每个更改以了解我做对了。代码如下: function loadAJAX() { ajaxRequest = new XMLHttpReq
我有一个执行基本 Ajax 发布的 AMD 模块。它正在工作,它将发布到我的服务器 api,但是 onreadystatechange 事件不会触发。你能看出我做错了什么吗?... define(['
我是一名优秀的程序员,十分优秀!