zoukankan      html  css  js  c++  java
  • 火狐对ajax的onreadystatechange与IE的不同。

    先看代码:

    function test1()
    {
        if (xmlHttpRequest == null)
        {
            xmlHttpRequest = CreateXmlHttpRequest();
        }

        var url = “test.ashx”;  

      同步请求
        xmlHttpRequest.open("GET", url, false);
        xmlHttpRequest.onreadystatechange = suc; 
        xmlHttpRequest.send(null);

       alert(1);
    }

    function suc()
    {f (xmlHttpRequest.readyState == 4)
        {
            if (xmlHttpRequest.status == 200)
            {

        alert(2);

       }

    }
    }

    上面的代码在ie中会先后弹出2,1,但是在火狐中只会弹出2.

    原因是在火狐中,如果ajax基于同步请求,那么代码是顺序执行的,同时不会触发onreadystatechange事件。

    当执行xmlHttpRequest.send(null);这一句时,不会立即执行alert(1);直至xmlHttpRequest有返回结果。

    在ie中也是顺序执行的,但是当执行xmlHttpRequest.send(null);这一句时,会不断的触发onreadystatechange直到执行alert(2);才执行alert(1);

    如果把上面的代码改成:

    function test1()
    {
        if (xmlHttpRequest == null)
        {
            xmlHttpRequest = CreateXmlHttpRequest();
        }

        var url = “test.ashx”;  

      异步步请求
        xmlHttpRequest.open("GET", url, true);
        xmlHttpRequest.onreadystatechange = suc; 
        xmlHttpRequest.send(null);

       alert(1);
    }

    function suc()
    {f (xmlHttpRequest.readyState == 4)
        {
            if (xmlHttpRequest.status == 200)
            {

        alert(2);

       }

    }
    }

    此时在ie或者火狐中,会返回相同的结果。所以在jquery中存在  

        if ( !s.async ) {
                onreadystatechange();
            }

    这样一行。

  • 相关阅读:
    第九周作业
    第八周作业
    第七周作业
    第六周作业
    JAVA面向对象详细总结
    父愁者联盟--需求规格说明书
    案例分析
    软件工程编程作业1
    构建之法观后提问
    第一次随笔——准备工作
  • 原文地址:https://www.cnblogs.com/lorgine/p/1858237.html
Copyright © 2011-2022 走看看