zoukankan      html  css  js  c++  java
  • Javascript 运行innerHTML中的script

    1. /* innerhtml.js
    2. * Copyright Ma Bingyao <andot@ujn.edu.cn>
    3. * Version: 1.9
    4. * LastModified: 2006-06-04
    5. * This library is free.  You can redistribute it and/or modify it.
    6. * http://www.coolcode.cn/?p=117
    7. */
    8. var global_html_pool = [];
    9. var global_script_pool = [];
    10. var global_script_src_pool = [];
    11. var global_lock_pool = [];
    12. var innerhtml_lock = null;
    13. var document_buffer = "";
    14. function set_innerHTML(obj_id, html, time) {
    15.     if (innerhtml_lock == null) {
    16.         innerhtml_lock = obj_id;
    17.     }
    18.     else if (typeof(time) == "undefined") {
    19.         global_lock_pool[obj_id + "_html"] = html;
    20.         window.setTimeout("set_innerHTML('" + obj_id + "', global_lock_pool['" + obj_id + "_html']);", 10);
    21.         return;
    22.     }
    23.     else if (innerhtml_lock != obj_id) {
    24.         global_lock_pool[obj_id + "_html"] = html;
    25.         window.setTimeout("set_innerHTML('" + obj_id + "', global_lock_pool['" + obj_id + "_html'], " + time + ");", 10);
    26.         return;
    27.     }
    28.     function get_script_id() {
    29.         return "script_" + (new Date()).getTime().toString(36)
    30.           + Math.floor(Math.random() * 100000000).toString(36);
    31.     }
    32.     document_buffer = "";
    33.     document.write = function (str) {
    34.         document_buffer += str;
    35.     }
    36.     document.writeln = function (str) {
    37.         document_buffer += str + "\n";
    38.     }
    39.     global_html_pool = [];
    40.     var scripts = [];
    41.     html = html.split(/<\/script>/i);
    42.     for (var i = 0; i < html.length; i++) {
    43.         global_html_pool[i] = html[i].replace(/<script[\s\S]*$/ig, "");
    44.         scripts[i] = {text: '', src: '' };
    45.         scripts[i].text = html[i].substr(global_html_pool[i].length);
    46.         scripts[i].src = scripts[i].text.substr(0, scripts[i].text.indexOf('>') + 1);
    47.         scripts[i].src = scripts[i].src.match(/src\s*=\s*(\"([^\"]*)\"|\'([^\']*)\'|([^\s]*)[\s>])/i);
    48.         if (scripts[i].src) {
    49.             if (scripts[i].src[2]) {
    50.                 scripts[i].src = scripts[i].src[2];
    51.             }
    52.             else if (scripts[i].src[3]) {
    53.                 scripts[i].src = scripts[i].src[3];
    54.             }
    55.             else if (scripts[i].src[4]) {
    56.                 scripts[i].src = scripts[i].src[4];
    57.             }
    58.             else {
    59.                 scripts[i].src = "";
    60.             }
    61.             scripts[i].text = "";
    62.         }
    63.         else {
    64.             scripts[i].src = "";
    65.             scripts[i].text = scripts[i].text.substr(scripts[i].text.indexOf('>') + 1);
    66.             scripts[i].text = scripts[i].text.replace(/^\s*<\!--\s*/g, "");
    67.         }
    68.     }
    69.     var s;
    70.     if (typeof(time) == "undefined") {
    71.         s = 0;
    72.     }
    73.     else {
    74.         s = time;
    75.     }
    76.     var script, add_script, remove_script;
    77.     for (var i = 0; i < scripts.length; i++) {
    78.         var add_html = "document_buffer += global_html_pool[" + i + "];\n";
    79.         add_html += "document.getElementById('" + obj_id + "').innerHTML = document_buffer;\n";
    80.         script = document.createElement("script");
    81.         if (scripts[i].src) {
    82.             script.src = scripts[i].src;
    83.             if (typeof(global_script_src_pool[script.src]) == "undefined") {
    84.                 global_script_src_pool[script.src] = true;
    85.                 s += 2000;
    86.             }
    87.             else {
    88.                 s += 10;
    89.             }
    90.         }
    91.         else {
    92.             script.text = scripts[i].text;
    93.             s += 10;
    94.         }
    95.         script.defer = true;
    96.         script.type"text/javascript";
    97.         script.id = get_script_id();
    98.         global_script_pool[script.id] = script;
    99.         add_script = add_html;
    100.         add_script += "document.getElementsByTagName('head').item(0)";
    101.         add_script += ".appendChild(global_script_pool['" + script.id + "']);\n";
    102.         window.setTimeout(add_script, s);
    103.         remove_script = "document.getElementsByTagName('head').item(0)";
    104.         remove_script += ".removeChild(document.getElementById('" + script.id + "'));\n";
    105.         remove_script += "delete global_script_pool['" + script.id + "'];\n";
    106.         window.setTimeout(remove_script, s + 10000);
    107.     }
    108.     var end_script = "if (document_buffer.match(/<\\/script>/i)) {\n";
    109.     end_script += "set_innerHTML('" + obj_id + "', document_buffer, " + s + ");\n";
    110.     end_script += "}\n";
    111.     end_script += "else {\n";
    112.     end_script += "document.getElementById('" + obj_id + "').innerHTML = document_buffer;\n";
    113.     end_script += "innerhtml_lock = null;\n";
    114.     end_script += "}";
    115.     window.setTimeout(end_script, s);
    116. }

    作者修正

    2006-6-4 更新:

    修正了插入到 innerHTML 中的脚本无法获取插入到 innerHTML 中对象的问题。(感谢网友 DE 的提醒)。

    增加了对同一容器中内容设置的共享锁,使得连续设置同一个容器内的时,不会再发生冲突。(感谢新加坡网友 Jason Li 的提醒)。

    2006-5-29 更新:

    增加了使用外部脚本缓存功能,提高了第二次加载相同外部脚本的速度。

    2006-5-23 更新:

    在热心的使用者 johnZEN 的提醒下,增加了共享锁,使得同时设置多个容器内的内容时,不会再发生冲突。

    在网友 udbjatwfn 的提醒下,修正了 IE 中存在的内部脚本执行作用域错误的问题。

    作者代码原贴地址:http://www.coolcode.cn/?p=117&cp=all#pp0

    今天在写AJAX的时候,碰到了obj.innerHTML = response.text时,如果返回的代码中,有<script>内容,则无法执行,网上看了些解决办法,基本思路应该是将innerHTML中的所有内容取出,然后分析,将其中的<script>内容取出,执行

    作者 andot 的分析内容比较全面,需要注意的有几个问题

    1.跨浏览器的兼容性的问题,在IE浏览器的情况下,只要在innerHTML里的script里加上defer属性即可,语法如下<script defer></script>,不过在其他浏览器下无效

    2.如果IE的<script>在innerHTML开头,会忽略掉,其他浏览器正常,解决办法是判断浏览器是否为IE,如果是IE则加上一些空的HTML标签

    其余解决中细节问题,在作者原文中有描述

  • 相关阅读:
    jQuery Ajax 实例
    jQuery Ajax 实例
    mysql中使用MySqlParameter操作数据库
    mysql中使用MySqlParameter操作数据库
    MySQL limit 分页查询数据库
    html5新特性data_*自定义属性使用
    CSS中zoom和scale的区别
    Linux下nginx编译安装教程和编译参数详解
    nginx.conf配置
    linux下tar.gz、tar、bz2、zip等解压缩、压缩命令小结
  • 原文地址:https://www.cnblogs.com/goody9807/p/1345063.html
Copyright © 2011-2022 走看看