我最近在愚弄一些Ajax轮询技术。但是,似乎我无法onreadystatechange
从XMLHttpRequest
FireFox(3.6.7)中的对象覆盖处理程序。
在跟踪为什么FF在尝试访问时引发异常的问题时onreadystatechange
,我意识到这取决于是否send()
调用了该方法。
换句话说,这是一个有效的示例(纯js,到目前为止没有jQuery):
(这只是为了演示而进行了相当简化)
var myxhr = new XMLHttpRequest();
myxhr.open("GET", "/my/index.php");
myxhr.onreadystatechange = function(){
console.log('ready state changed');
};
console.log("onreadystatechange function: ", myxhr.onreadystatechange);
myxhr.send(null);
更好的说是可行的,可以myxhr.onreadystatechange
在这里访问。如果我切换最后两行代码,FF会引发异常,基本上是告诉我不允许访问此对象。
myxhr.send(null);
console.log("onreadystatechange function: ", myxhr.onreadystatechange);
失败
那么我的实际问题在哪里?
好吧,我想使用jQuery的$.ajax()
。但是,如果我尝试覆盖从返回onreadystatechange
的XHR
对象的方法,则会$.ajax()
收到相同的FireFox异常。
好的,我已经发现了为什么会发生这种情况,所以我考虑了,嘿,那的beforeSend
属性$.ajax()
呢?所以我基本上尝试了这个:
var myxhr = $.ajax({
url: "/my/index.php",
type: "GET",
dataType: "text",
data: {
foo: "1"
},
beforeSend: function(xhr){
var readystatehook = xhr.onreadystatechange;
xhr.onreadystatechange = function(){
readystatehook.apply(this, []);
console.log('fired');
};
},
success: function(data){
console.log(data);
},
error: function(xhr, textStatus, error){
console.log(xhr.statusText, textStatus, error);
}
});
猜猜是什么,FireFox引发异常。那你现在怎么办?您像我一样深入jQuery源码。但这带来的问题多于答案。看起来beforeSend()
在xhr.send()
执行之前确实被调用了。所以我想知道为什么FireFox在这一点上不允许覆盖处理程序。
结论?
custom readystatechange handler
用jQuery / Firefox 创建一个吗?
我在这里同意Maz的观点,您仍然可以从查询处理和对象创建中受益,并且也无需为此修补jquery
但是,如果您不介意修补jquery,则可以添加以下行
// The readystate 2
} else if ( !requestDone && xhr && xhr.readyState === 2 && isTimeout !== 'timeout' && s.state2) {
s.state2.call( s.context, data, status, xhr );
// The readystate 3
} else if ( !requestDone && xhr && xhr.readyState === 3 && isTimeout !== 'timeout' && s.state3) {
s.state3.call( s.context, data, status, xhr );
在此行之前:(jQuery v 1.4.4)或仅在源代码中搜索readyState === 4
// The transfer is complete and the data is available, or the request timed out
} else if ( !requestDone && xhr && (xhr.readyState === 4 || isTimeout === "timeout") ) {
现在您可以再次使用$ .ajax并为state2和state3设置一个处理程序,如下所示:
$.ajax({
url: 'http://www.stackoverflow.com',
cache: false,
success:function(){console.log('success');},
error: function (){console.log('error');},
complete: function (){console.log('complete');},
state2: function (context,data,status,xhr) {console.log('state2');},
state3: function (context,data,status,xhr) {console.log('state3');}
});
它的行为与其他处理程序完全不同,例如returngin false不会做任何事情,但是您仍然可以处理xhr对象并以这种方式中止
虐待看看我是否可以在今天晚些时候将其提交以包含在源中,谁知道他们可能会接受它
问题内容: 我正在开发一些基于Web服务的应用程序,并且对Apache CXF解组有疑问。在我们的项目中,我们使用CXF 2.4.1版本。 当某些SOAP请求不正确时(例如,某些字段是文本而不是数字),CXF会抛出标准的SOAPFaultException,并且SOAP响应将使用以下标准字段构建: 项目要求说,如果发生任何故障,系统需要以其他格式响应,例如: 所以问题是:如何以某种方式覆盖此错误处
我无法覆盖REST API中默认的Spring Boot错误响应。我有以下代码 然后在我的REST api中抛出这个BusinessValidationException。这个处理程序被调用(我可以在调试器中看到它),但是我仍然得到缺省的Spring BootREST错误消息。是否有一种方法可以重写并仅将default用作后退?带有Groovy的Spring Boot版本1.3.2。最诚挚的问候
在下图中,我想把分数作为绿色椭圆内的文本。但是,不管循环中的和函数的顺序如何,椭圆都会在文本上绘制。有人能提出原因吗?我的循环如下所示。
我正试图得到所有的点击我的覆盖,我不知道angular是忽略他时,我点击另一个元素下的覆盖。 我创建了这个stackblitz,以查看问题是否发生在另一个地方,但我也遇到了类似的问题。https://stackblitz.com/edit/Angular-ivy-SJKWKC?file=src%2fapp%2fapp.component.html null null
我不熟悉java、Junit和jacoco。我正在做下面的异常处理。我也在捕获异常类,以防该方法抛出之前未捕获的任何其他异常。 在Junit测试中,尝试如下。当我有运行时的任何异常时,我抛出的总是运行时异常捕获块本身,除非我抛出异常。我可以尝试其他哪个选中的异常,使其进入异常捕获块。因此,我无法获得所需的代码覆盖率。 谢谢你的帮助。
假设我们正在运行一个程序,想从当前程序运行另一个程序。 这可能吗? 如果我们实现覆盖进程映像的概念。 当前正在运行的程序呢,也可以运行的。 当前的程序与新程序叠加,如果想运行两个程序,而不会丢失当前正在运行的程序,有可能吗?这是可能做到的。 创建一个子进程,以便有一个父进程和一个新创建的子进程。 我们已经在父进程中运行当前程序,所以在子进程中运行新创建的进程。 这样可以从当前程序运行另一个程序。