国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

javascript中動態(tài)加載js文件多種解決辦法總結(jié)

2024-05-06 15:55:07
字體:
供稿:網(wǎng)友
這篇文章主要介紹了javascript中動態(tài)加載js文件多種解決辦法,有需要的朋友可以參考一下

一個比較全部在動態(tài)加方法

復(fù)制代碼 代碼如下:


/*
    動態(tài)加載js v1.0 by:dum
    用法:src="webJsBase.js?load=a,b"
    注:加載本目錄下js
*/
var webJsBase = {
    require: function(libraryName) {
        document.write('<script type="text/javascript" src="'+libraryName+'"></script>');
    },
    load: function(defaultLoad) {
        if((typeof Prototype=='undefined')||(typeof Element == 'undefined')||(typeof Element.Methods=='undefined'))
        throw ('prototype lib 加載失敗!');
        if(typeof defaultLoad=='undefined')defaultLoad='';
        var js = /webJsBase.js(?.*)?$/;
        $$('head script[src]').findAll(function(s) {
            return s.src.match(js);
        }).each(function(s) {
            var path = s.src.replace(js, '');
            var includes = s.src.match(/?.*load=([a-zA-Z0-9_,]*)/);
            (includes ? includes[1] : defaultLoad).split(',').each(function(include) {
                webJsBase.require(path + include + '.js');
            });
        });
    }
};
webJsBase.load(); //這里參數(shù)可以指定默認(rèn)要加載的js文件

這是最簡單的方法在加載完后再利用直接document.write 如下圖。

復(fù)制代碼 代碼如下:


<script language="javascript">

    document.write("<script src='test.js'></script>");

</script>

給script加個id再去動態(tài)改變已有script的src 屬性

復(fù)制代碼 代碼如下:


<script src=''></script>

<script language="javascript">

    s1.src="test.js"

</script>

這里利用getElementsByTagName('HEAD')動態(tài)創(chuàng)建 script元素

復(fù)制代碼 代碼如下:


<script>

    var oHead = document.getElementsByTagName('HEAD').item(0);

    var oScript= document.createElement("script");

    oScript.type = "text/javascript";

    oScript.src="test.js";

    oHead.appendChild( oScript);

</script>

還可以這樣嘗試一下,自定一個函數(shù)

復(fù)制代碼 代碼如下:


function include(src) {
HTMLCode = '<script language="javascript" src="' + src + '"></script>';
document.write(HTMLCode);
}


調(diào)用方法,這樣看上去就你php的include函數(shù)了

復(fù)制代碼 代碼如下:


include(baseDir + "/Prototype.js");
include(baseDir + "/Map.js");
include(baseDir + "/MapEvent.js");

include(baseDir + "/model/MapModel.js");
include(baseDir + "/model/MapType.js");
include(baseDir + "/model/Tile.js");

還有朋友說可以使用ExtJs4 動態(tài)加載js這里我就不介紹了,上面的方法足夠讓你實(shí)現(xiàn)動態(tài)加載js了.

所以在采用這類方法動態(tài)加載Js 的同時,主界面的Js腳本是繼續(xù)執(zhí)行的,所以可能出現(xiàn)通過異步加載的Js代碼得不到預(yù)期的效果的情況。

這時候可以考慮采用Ajax加載Js的方法。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 宁南县| 铜山县| 定结县| 靖边县| 凤庆县| 南雄市| 泸溪县| 宝山区| 潞城市| 阜城县| 无为县| 蕉岭县| 澜沧| 锦州市| 泰顺县| 武义县| 乌恰县| 罗定市| 新兴县| 贵南县| 榆树市| 美姑县| 塔城市| 固镇县| 天等县| 清水县| 监利县| 张家界市| 兴文县| 东方市| 通许县| 赤峰市| 申扎县| 肥西县| 通渭县| 蓬莱市| 新宁县| 白银市| 七台河市| 松阳县| 吕梁市|