Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 559|回复: 0

ajax innerHTML 拼接js 不执行,呈现解决方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-9-5 12:41:35 | 显示全部楼层 |阅读模式

    源代码:

    $.ajax({

    url : "<%=request.getContextPath()%>/cartree/testCartree.action",

    type : "GET",

    cache : false,

    async : false,

    data : {

    "method" : "selFun"

    },

    dataType : "json",

    contentType: "application/x-www-form-urlencoded; charset=utf-8", 

    success : function(json){

    var lsgj_tree_context = "<script type=\"text/javascript\">"

    +"c = new dTree(\"c\");"

    +"c.config.useCookies = false;"

    +"c.config.useStatusText = true;"

    +"c.config.closeSameLevel = true;";

     

    for(var i=0;i<json.length;i++){

    if(json.deptNo == "0"){

    //root 根目录

        lsgj_tree_context += "c.add("+json.deptNo+", -1, \""+json.deptName+"\");";

    }else{

    // 一级目录

    lsgj_tree_context += "c.add("+json.deptNo+", 0, \""+json.deptName+"\", \"\", \"\",\"\", \"\", \"\", \"\", \"cradio\", \"radio\", \"\",\"\");";

    var carObj = json.carObjList;

     

    for(var j =0;j<carObj.length;j++){

    // 二级目录

        lsgj_tree_context+="c.add("+carObj[j].cid+", "+json.deptNo+", \""+carObj[j].ccp+"\", \"\", \"\", \"\", \"\", \"\", \"\", \"cradio\", \"radio\", \"\",\"\");";

    }

    }

    }

     

    lsgj_tree_context+="document.write(c);";

    lsgj_tree_context+=" </script";

    lsgj_tree_context+=">";

    alert(lsgj_tree_context);

    document.getElementById("lsgj_tree").innerHTML =lsgj_tree_context;

     

    }

     });

    问题ajax innerHTML在拼接js字符串放入指定标签的时候,标签内js不能正常执行

     

    解决办法引用innerHTML.js ,调用set_innerHTML方法

    (1)<script type="text/javascript" src="<%=request.getContextPath()%>/common/innerhtml.js"></script>

    (2)$.ajax({

    url : "<%=request.getContextPath()%>/cartree/getListCartree.action",

    type : "GET",

    cache : false,

    async : false,

    data : {

    "method" : "selFun"

    },

    dataType : "json",

    contentType: "application/x-www-form-urlencoded; charset=utf-8", 

    success : function(json){

    var ssjk_tree_context = "<script type=\"text/javascript\">"

    +"a = new dTree(\"a\");"

    +"a.config.useCookies = false;"

    +"a.config.useStatusText = true;"

    +"a.config.closeSameLevel = false;"; // 判断是否兄弟菜单同时展开

     

    for(var i=0;i<json.length;i++){

    if(json.deptNo == "0"){

    //root 根目录

        ssjk_tree_context += "a.add("+json.deptNo+", -1, \""+json.deptName+"\");";

    }else{

    // 一级目录

    ssjk_tree_context += "a.add("+json.deptNo+", 0, \""+json.deptName+"\", \"\", \"\",\"\", \"\", \"\", \"\", \"aradio\", \"checkbox\", \"\",\"\");";

    var carObj = json.carObjList;

     

    for(var j =0;j<carObj.length;j++){

    // 二级目录

        ssjk_tree_context+="a.add("+carObj[j].cid+", "+json.deptNo+", \""+carObj[j].ccp+"\", \"\", \"\", \"\", \"\", \"\", \"\", \"aradio\", \"checkbox\", \"\",\"\");";

    }

    }

    }

     

    ssjk_tree_context+="document.write(a);";

    ssjk_tree_context+=" <\/script";

    ssjk_tree_context+=">";

    set_innerHTML("ssjk_tree",ssjk_tree_context,""); // 将js利用innerHTML添加到指定标签

     

    }

     });

     

    注:innerHTML.js 代码

    /* innerhtml.js 

    * Copyright Ma Bingyao <andot@ujn.edu.cn> 

    * Version: 1.9 

    * LastModified: 2006-06-04 

    * This library is free.  You can redistribute it and/or modify it. 

    * http://www.coolcode.cn/?p=117 

    */ 

       

    var global_html_pool = []; 

    var global_script_pool = []; 

    var global_script_src_pool = []; 

    var global_lock_pool = []; 

    var innerhtml_lock = null; 

    var document_buffer = ""; 

       

    function set_innerHTML(obj_id, html, time) { 

        if (innerhtml_lock == null) { 

            innerhtml_lock = obj_id; 

        } 

        else if (typeof(time) == "undefined") { 

            global_lock_pool[obj_id + "_html"] = html; 

            window.setTimeout("set_innerHTML('" + obj_id + "', global_lock_pool['" + obj_id + "_html']);", 10); 

            return; 

        } 

        else if (innerhtml_lock != obj_id) { 

            global_lock_pool[obj_id + "_html"] = html; 

            window.setTimeout("set_innerHTML('" + obj_id + "', global_lock_pool['" + obj_id + "_html'], " + time + ");", 10); 

            return; 

        } 

       

        function get_script_id() { 

            return "script_" + (new Date()).getTime().toString(36) 

              + Math.floor(Math.random() * 100000000).toString(36); 

        } 

       

        document_buffer = ""; 

       

        document.write = function (str) { 

            document_buffer += str; 

        } 

        document.writeln = function (str) { 

            document_buffer += str + "\n"; 

        } 

       

        global_html_pool = []; 

       

        var scripts = []; 

        html = html.split(/<\/script>/i); 

        for (var i = 0; i < html.length; i++) { 

            global_html_pool = html.replace(/<script[\s\S]*$/ig, ""); 

            scripts = {text: '', src: '' }; 

            scripts.text = html.substr(global_html_pool.length); 

            scripts.src = scripts.text.substr(0, scripts.text.indexOf('>') + 1); 

            scripts.src = scripts.src.match(/src\s*=\s*(\"([^\"]*)\"|\'([^\']*)\'|([^\s]*)[\s>])/i); 

            if (scripts.src) { 

                if (scripts.src[2]) { 

                    scripts.src = scripts.src[2]; 

                } 

                else if (scripts.src[3]) { 

                    scripts.src = scripts.src[3]; 

                } 

                else if (scripts.src[4]) { 

                    scripts.src = scripts.src[4]; 

                } 

                else { 

                    scripts.src = ""; 

                } 

                scripts.text = ""; 

            } 

            else { 

                scripts.src = ""; 

                scripts.text = scripts.text.substr(scripts.text.indexOf('>') + 1); 

                scripts.text = scripts.text.replace(/^\s*<\!--\s*/g, ""); 

            } 

        } 

       

        var s; 

        if (typeof(time) == "undefined") { 

            s = 0; 

        } 

        else { 

            s = time; 

        } 

       

        var script, add_script, remove_script; 

       

        for (var i = 0; i < scripts.length; i++) { 

            var add_html = "document_buffer += global_html_pool[" + i + "];\n"; 

            add_html += "document.getElementById('" + obj_id + "').innerHTML = document_buffer;\n"; 

            script = document.createElement("script"); 

            if (scripts.src) { 

                script.src = scripts.src; 

                if (typeof(global_script_src_pool[script.src]) == "undefined") { 

                    global_script_src_pool[script.src] = true; 

                    s += 2000; 

                } 

                else { 

                    s += 10; 

                } 

            } 

            else { 

                script.text = scripts.text; 

                s += 10; 

            } 

            script.defer = true; 

            script.type =  "text/javascript"; 

            script.id = get_script_id(); 

            global_script_pool[script.id] = script; 

            add_script = add_html; 

            add_script += "document.getElementsByTagName('head').item(0)"; 

            add_script += ".appendChild(global_script_pool['" + script.id + "']);\n"; 

            window.setTimeout(add_script, s); 

            remove_script = "document.getElementsByTagName('head').item(0)"; 

            remove_script += ".removeChild(document.getElementById('" + script.id + "'));\n"; 

            remove_script += "delete global_script_pool['" + script.id + "'];\n"; 

            window.setTimeout(remove_script, s + 10000); 

        } 

       

        var end_script = "if (document_buffer.match(/<\\/script>/i)) {\n"; 

        end_script += "set_innerHTML('" + obj_id + "', document_buffer, " + s + ");\n"; 

        end_script += "}\n"; 

        end_script += "else {\n"; 

        end_script += "document.getElementById('" + obj_id + "').innerHTML = document_buffer;\n"; 

        end_script += "innerhtml_lock = null;\n"; 

        end_script += "}"; 

        window.setTimeout(end_script, s); 

    }

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-4-23 19:14 , Processed in 0.107918 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表