1

我正在使用 JavaScript 动态加载 jQuery。为了加载 jQuery,定义了回调函数,并在其回调函数中调用了一些 jQuery 的东西。

正如预期的那样在 Firefox、chrome 和 IE9 中运行良好,但在 IE8 中给出错误消息,如“$ 未定义”意味着 IE8 中的回调函数执行存在问题。我花了一整天的时间寻找解决方案,但没有任何办法。

<body>    
<script language="javascript" type="text/javascript">
    function loadjQuery(callback) {
        var ver = getInternetExplorerVersion();

        var body = document.getElementsByTagName('body')[0];
        var script = document.createElement('script');
        script.type = 'text/javascript';
        if (ver == 8.0) {
            script.onload = callback.call();
        }
        else {
            script.onload = callback;
        }
        script.src = 'http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js';
        body.appendChild(script);
    }
    loadjQuery(function () {
        alert($(window).height());       
    });

    function getInternetExplorerVersion() {
        var rv = -1;
        if (navigator.appName == 'Microsoft Internet Explorer') {
            var ua = navigator.userAgent;
            var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})");
            if (re.exec(ua) != null)
                rv = parseFloat(RegExp.$1);
        }
        return rv;
    }
    </script>
</body>

我完全被困住了。有什么帮助吗?

4

1 回答 1

1

我曾经也编写过这个函数,下面的代码看起来很完美:

            // Attach handlers for all browsers
            script.onload = script.onreadystatechange = function() {

                if (!done && (!this.readyState || this.readyState == 'loaded' || this.readyState == 'complete')) {
                    done = true;                        
                    // callback function provided as param
                    if(success != null)
                    {
                        success();
                    }
                    script.onload = script.onreadystatechange = null;
                    //head.removeChild(script);                     
                };              
            };     
于 2013-02-28T06:22:38.443 回答