位置:海鸟网 > IT > JavaScript >

怎样确保JavaScript的执行顺序

 service.ashx,它可以接受两个参数:

1.      file,需要返回文件的服务器端路径。

2.      delay,延迟一定时间后再返回本次HTTP请求(毫秒)。

一个典型的页面比如:./service.ashx?file=/jquery-ui.js&delay=2000,表示延迟2秒钟后再返回服务器端的js/jquery-ui.js文件。

service.ashx 的关键代码如下:

public void ProcessRequest(HttpContext context)

{

    int delay = 0;

    if (!String.IsNullOrEmpty(context.Request["delay"]))

    {

        delay = Convert.ToInt32(context.Request["delay"]);

    }

    if (delay > 0)

    {

        System.Threading.Thread.Sleep(1000);

    }

    string filePath = context.Request["file"].ToString();

    string fileContent = String.Empty;

    using (StreamReader sr = new StreamReader(context.Server.MapPath(filePath)))

    {

        fileContent = sr.ReadToEnd();

    }

    if (filePath.EndsWith(".js"))

    {

        context.Response.ContentType = "application/x-javascript";

    }

    else

    {

        context.Response.ContentType = "text/plain";

    }

    context.Response.Write(fileContent);

}

2.     通过script标签直接引入JavaScripttest1.htm

首先我们分析下在<head>标签中顺序引入JavaScript的情况。test1.htm的页面源代码如下:

<html>

<head>

    <title></title>

<script src="./js/jquery-1.4.4.js"  

              type="text/javascript"></script>

<script src="./service.ashx?file=js/jquery-ui.js&delay=2000"

              type="text/javascript"></script>

    <script>

                 alert(typeof (jQuery.ui));

    </script>

</head>

<body>

</body>

</html>

我们分别在各种浏览器中测试这个例子:


可以看出各个主流浏览器的行为一致。虽然jQueryUI在服务器延迟了2秒钟再返回,但是后引入的内联JavaScript还是等待了2秒,等前面引入的JavaScript执行完毕才执行。这也是著名的JavaScript顺序执行的特性。

3.     通过JavaScript添加script标签(test3.htm

我们首先定义一个addScript函数,用来引入外部或者内联JavaScripttest3.htm的页面源代码如下:

<html>

<head>

    <title></title>

    <script src="./js/jquery-1.4.4.js" type="text/javascript"></script>

    <script>

        function addScript(url, inline) {

            var head = document.getElementsByTagName("head")[0];

            var script = document.createElement('script');

            script.type = 'text/javascript';

            if (inline) {

                script.text = url;

            } else {

                script.src = url;

            }

            head.appendChild(script);

        }

        $(function () {

            addScript('./service.ashx?file=js/jquery-ui.js&delay=2000');

            addScript('alert(typeof(jQuery.ui));', true);

        });

    </script>

</head>

<body>

    <div id="container">

    </div>

</body>

</html>

我们分别在各种浏览器中测试这个例子:


JavaScriptJavaScript

Opera确保执行顺序)。

其实解决方案很简单,我们为函数执行添加一个complete的回调函数就行了。下面的test4.htm给出了具体的解决方案:

<html>

<head>

    <title></title>

    <script src="./js/jquery-1.4.4.js" type="text/javascript"></script>

    <script>

        function addScript(url, inline, callback) {

            var head = document.getElementsByTagName("head")[0];

            var script = document.createElement('script');

            script.type = 'text/javascript';

            if (inline) {

                script.text = url;

            } else {

                script.src = url;

                script.onload = script.onreadystatechange = function () {

                    if (!script.readyState || script.readyState === 'loaded' || script.readyState === 'complete') {

                        if (callback) {

                            callback();

                        }

                        script.onload = script.onreadystatechange = null;

                    };

                };

            }

            head.appendChild(script);

            if (inline && callback) {

                callback();

            }

        }

        $(function () {

            addScript('./service.ashx?file=js/jquery-ui.js&delay=2000', false, function () {

                addScript('alert(typeof(jQuery.ui));', true);

            });

        });

    </script>

</head>

<body>

    <div id="container">

    </div>

</body>

</html>

此时所有浏览器中的行为一致:


5.     方案二,使用jQueryhtml函数动态添加JavaScript

jQueryhtml函数用来更新一个DOM片段,我们可以很方便的通过这个函数来动态加载JavaScript,请看示例test2.htm

<html>

<head>

    <title></title>

    <script src="js/jquery-1.4.4.js" type="text/javascript"></script>

    <script>

        $(function(){

            $('#container').html('<script src="./service.ashx?file=js/jquery-ui.js&delay=2000" type="text\/javascript"><\/script>' + '<script>alert(typeof(jQuery.ui));<\/script>');

        });

    </script>

</head>

<body>

    <div id="container">

    </div>

</body>

</html>

此时,各个浏览器中的行为一致:


JavaScriptjQuery.html深度分析。 - 待续。。。