如何让动态插入的脚本物业
高平历史网 2021-10-29 05:48:27
首先,声明方法很多种,直接间接的方法都有,只罗列一般情况下的两种模式:
假设我们要装入的代码是:
var foo=function(){
ite(\"I am content foo() function\");
};
一。直接插入src,这种方法简单而直接,但有局限性,
1) script
var x=eateElement(\"SCRIPT\");
c=\"\"; fer=true;
tElementsByTagName(\"HEAD\")[0].appendChild(x);
foo();
/script
在如上的代码放上head标签内,执行时大多数情况下是会出错,信息为:错误:缺少对象
这是由于动态创建对象script时,则于还没有完全载入而导致的。执行下面的代码,你就可以发现原因了。
html
head
metahttp-equiv=\"Content-Type\"content=\"text/html;charset=gb2312\"
titlenever-onlinedynamiccodetestpage/title
/head
body
pre
readyState的含义
-uninitialized:脚本对象刚被创建,脚本代码未载入;
-loading:脚本代码载入中;
-loaded:脚本代码完成读入,但尚未开始解释执行;
-interactive:解释执行过程中;
-complete:脚本已经执行完成。
/pre
divid=\"viewer\"/div
scripttype=\"text/javascript\"...
error=function(msg,url,line)...{
tElementById(\"viewer\").innerHTML+=\'pstyle=\"color:red\"错误:\'+msg+\'line:\'+line+\'/p\';
returntrue;
}
functionbar(u)...{
varx=eateElement(\"SCRIPT\");
c=u;
fer=true;
tElementsByTagName(\"HEAD\")[0].appendChild(x);
}
提高融资效率 bar(\"\");
(functiongetReadyState()...{
vare=tElementById(\"viewer\")
varx=true;
vara=tElementsByTagName(\"SCRIPT\");
for(vari=0;ngth;i++)...{
if(a[i].readyState==\'complete\'x!=false)x=true;elsex=false
nerHTML+=(a[i].src?a[i].src+\':\':\'noname:\')+a[i].readyState+\"br/\";
}
nerHTML+=\"hr/\";
if(x)earTimeout(mer);else
mer=tTimeout(\'getReadyState()\',1000);
}());
foo();
/script
scripttype=\"text/javascript\"...
//![CDATA[
foo();
//]]
/script
/body
/html
初始值为:
:loading
noname:interactive
我们可以知道,依然在loading状态,在执行foo()当然是错误的。但下一个script标签执行中,的readyState是complete了,所以可以执行foo()的函数。由此,我推荐你可以简单的这样运用动态用生成script标签方法来添加js的url。
解决方法如下
1)用tTimeout方法来执行,估计已经载入完毕,才执行里的函数。这个方法仍然不保险
script
var x=eateElement(\"SCRIPT\");
c=\"\"; fer=true;
tElementsByTagName(\"HEAD\")[0].appendChild(x);
tTimeout(\'foo()\',1000);
/script
2)多加一个script标签放置要执行的代码 script
var x=eateElement(\"SCRIPT\");
c=\"\"; fer=true;
tElementsByTagName(\"HEAD\")[0].appendChild(x);
/script
script
//多一个script标签来放置
//这里的readyState已经为complete了。
foo();
/script
二、用XMLHttpRequest和ecScript动态的执行,这个方法的优点比较明显,但效率可能有所下降,没有测试,有兴趣的朋友可以自己测试一下速度。
代码如下: script language=\"javascript\"
function bar(u) {
var x=tiveXObject?new ActiveXObject(\"LHTTP\"):new XMLHttpRequest();
en(\"GET\",u,false);
nd(null);
s=sponseText;
try {ecScript(s)}catch(ex){al(s)};//Mozilla下al大致与IE的ecScript方法功能相同
}
bar(\"\");
foo();
/script
但这个方法仍有缺点,也就是脚本中的代码有中文的情况,如何处理?那就要经常解码了,而解码恰恰是js的软肋,如果运用vbs来解码,那么兼容也就没有了。要看自己具体的应用了,我在neverModules里加载js包时用的就是ecScript方法来解析代码,这样更可以配合js namespace的应用
加上脚本解码(用vbs来解码):
scripttype=\"text/javascript\"
//![CDATA[
functionbar(u)...{
varx=tiveXObject?newActiveXObject(\"LHTTP\"):newXMLHttpRequest();
en(\"GET\",u,false);
nd(null);
s=parseScript(sponseText);
try...{ecScript(s)}catch(ex)...{al(s)};
}
functionparseScript(jscode)...{
//---toCurrentCharset(),byaimingoo解码
ecScript(\'\'+
\'FunctionAsc2Unicode(n) \'+
\'Asc2Unicode=Chr(n) \'+
\'EndFunction \'+
\'FunctionSafeArray2Str(body) \'+
\'SafeArray2Str=CStr(body) \'+
\'EndFunction\',\'VBScript\');
varr1=/%u(..)(..)/g,r2=/%([8,9,A-F].)%(..)/g;
vartoUnicode=function($0,$1,$2)...{returnAsc2Unicode(parseInt($1+$2,16))}
toCurrentCharset=function(body)...{
returnunescape(escape(SafeArray2Str(body)).replace(r1,\"%$2%$1\").replace(r2,toUnicode));
};jscode=toCurrentCharset(jscode);
ecScript(jscode,\'JavaScript\');//IE有效,vbs解码
returnjscode;
}
bar(\'\');
foo();
//]]
/script
不过大多数的情况下,第二种方法处理起来应该没有问题,如果要很严格的执行的话,第一种方法还是有改进的代码的,比如加载的内容,把本身的脚本再次解析再执行,但复杂度就提高了,所以要有一个非常完美的解决方案,还需要更进一步来讨论。
我就不写这么多了,仅仅为一个提醒,还有一个抛砖引玉的作用。
多梦易醒怎么办台州阴道炎治疗费用
重庆青春痘
- 上一页:如何让你的数据库产生一张详细的日历表
- 下一页:如何让用户不能但可以计划
- 我发现情商越高的人,在为人处世中,就会越“禁忌”这3条
- 中梁控股提前注销1.5亿美元2022年8月本票
- 研究者终于知道土星现在几点了
- 水乳不是越贵越好,分享4款高性价比水乳,看齐也能养出好皮肤
- (中国这十年·系列主题新闻发布)连续迈上新台阶,我国国际贸易十年交出亮眼答卷
- 廖彬宇先生七言选:妖女吟五绝(外两首)
- 良品铺子:合计持股7.51%的高瓴拟减持不超6%公司的股份
- 智能手机业务萎靡,小米一季报承压,网友呼唤“摩托车翻身”
- 奥特维(688516.SH)子公司与合盛硅业(603260.SH)原为签订1.3亿元160型单晶炉买
- 平安人寿董事长杨铮任职申请人获批
- 安阳市金水区新奇初级中学2022年招生简章
- iPhone上的这个间谍触控板可以使打字更容易