前端入门(二):点击ztree节点通过ajax加载节点的详细信息

一、准备工作:

1. 新建一个dynamic web project,或者maven项目。

2. 在webcontent(或webapp)目录下面创建css文件夹和js文件夹,放置所需的依赖

3. 本项目下载地址https://github.com/dongyuguoai1/spingBootRestRM

二、代码编写

1. ztreeClickTest.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">

<span style="font-size:12px;"><!--表格树引用的js -->  
    <script type="text/javascript" src="../js/jquery.min.js"></script>  
    <script type="text/javascript" src="../js/ztree/jquery.ztree.core.js"></script>  
    <script type="text/javascript" src="../js/ztree/jquery.ztree.excheck.js"></script>  
    <script type="text/javascript" src="../js/ztree/jquery.ztree.exedit.js"></script>  
    <link rel="stylesheet" href="../css/ztree/zTreeStyle.css" type="text/css"></span>  

<title>ztree click</title>

<span style="font-size:12px;"> </span>  
<span style="font-size:12px;">自己可以去下载文档,然后根据位置引用文件,不要搞忘哦→_→</span>  
</head>
<body>
<span style="font-size:14px;">css我就直接写在里面了,有的样式没写,嫌麻烦→_→自己调整</span>

<span style="font-size:14px;"> </span><span style="font-size:14px;font-weight: normal;"><div class="tab-content" style="min-width: 376px; height: 258px; float: left; overflow: hidden; margin: -8px 0 0 0; padding: 0;">  
                        <!--知识库左边树形结构 -->  
                        <div class="tab_content_ztree" style=" width: 170px; height: 260px;overflow: auto;color: yellow;float: left;">  
                            <ul id="demoZtree" class="ztree">  
                                <li>111</li>  
                            </ul>  
                        </div>  
                        <!--知识库右边→_→说明 -->  
                        <div class="tab_content_ztree_explain" style="  width: 183px;  
            height: 250px;  
            overflow: auto;  
            color: #7e7e7e;  
            float: left;  
            border-left: 1px solid #E2E2E5;  
            padding: 4px;  
            font-size: 12px;  
            line-height: 14px;">  
                            <p><b id="tab_content_ztree_explain_title">参考答案</b> </p>  
                            <p id="tab_content_ztree_explain">  
                                 <frame src="share002_tree.do" name="treeFrame" id="treeFrame" frameborder="0" scrolling="auto" noresize="noresize" marginwidth="0" marginheight="0" />  
                                 
                  
                            </p>  
                        </div>  
                    </div></span>  
                    
                    
<script> 
//这部分是直接创建的ztree树结构,当然还可以动态创建,~~~~(>_<)~~~~  
$(function(){  
    var zNodes = [  
 { "id":0, "name":"供热质量",  
     children: [  
     { "id":1, "name":"供热系统"},  
     { "id":2, "name":"供热设施"},  
     { "id":3, "name":"用热户"}  
     ]  
 },  
 { "id":4, "name":"服务质量",  
     children: [  
   { "id":5, "name":"供热温度"},  
   { "id":6, "name":"用户室温检测"},  
   { "id":7, "name":"供热水质"}  
     ]  
 },  
  { "id":8, "name":"报修",  
      children: [  
    { "id":9, "name":"test3"},  
    { "id":10, "name":"test4"},  
    { "id":11, "name":"test5"}  
      ]  
  },  
   { "id":12, "name":"咨询",  
       children: [  
     { "id":13, "name":"test3"},  
     { "id":14, "name":"test4"},  
     { "id":15, "name":"test5"}  
       ]  
   },  
   { "id":16, "name":"建议",  
       children: [  
     { "id":17, "name":"test3"},  
     { "id":18, "name":"test4"},  
     { "id":19, "name":"test5"}  
       ]  
   },  
    ]  
   
    //模拟数据  
    var MoNidata = [  
        [   
            {"optionKey":"1", "optionValue":"Canon in D"},   
            {"optionKey":"2", "optionValue":"Wind Song"},   
            {"optionKey":"3", "optionValue":"Wings"}   
        ]   
    ]  
    //ztree子节点点击事件
    var datajson = new Object();
    function zTreeOnClick(event, treeId, treeNode) {  
        // alert(treeNode.tId + ", " + treeNode.name);  
        $("#eventProblemDesc1").html(treeNode.name);  
         
       //插入节点到右边的框内   $("#tab_content_ztree_explain").html(treeNode.name+':');  
        //利用ajax获取ztree对应节点的信息  
        $.ajax({   
            type:"GET",   
            url:"../ztreeTest/music.txt", //从服务器拿东西,地址自己写  
            dataType:"text",  
            //下面这个函数是在ajax请求成功后才执行的,其中的参数data,就是
            //请求到的数据(服务器对ajax请求做出的响应),即music.txt中的数据
            success:function(data){   
                //利用Selected获取 zTree 当前被选中的节点数据集合(下面两个语句根据ztreeAPI写的)  
                var treeObj = $.fn.zTree.getZTreeObj("demoZtree");  
                var nodes = treeObj.getSelectedNodes();  
              datajson = JSON.parse(data);
               // console.log(nodes); 下面通过ID对比循环判断,把txt里面的json数据的id拿来和树的id进行比较  
                for (var i = 0; i < datajson.length; i++) {  
                    var item = datajson[i];  
                    if(item.id == nodes[0].id){  
                       // alert(item.name);  
                            var music="<p>";   
                           music+=item.answer+"</p>";   
                            $('#tab_content_ztree_explain').html(music); //把json里想要的值赋给变量music,然后插入到div中  

                    }  
                }  
                 
            }   
        });   
        return false;   

    };  

     
//ztree设置常规的东西  
    var setting = {  
        callback: {  
            onClick: zTreeOnClick  
        },  

        view:{showLine:true, showIcon: false}  

      
          
    };  

    $.fn.zTree.init($("#demoZtree"), setting, zNodes);  

});  
</script> 


</body>
</html>

2. music.txt

[   
{"id":"0", "content":"Canon in D Canon in D Canon in D","answer":"hellow"},   
{"id":"1", "content":"C","answer":"yellow"},   
{"id":"2", "content":"123","answer":"cool"},   
{"id":"3", "content":"Wings","answer":"father"},  
{"id":"4", "content":"abC","answer":"uncle"},   
{"id":"5", "content":"qwe123","answer":"baby"},   
{"id":"6", "content":"zxcWings","answer":"luagh"}  
] 

三、右键工程,run on server 或运行项目的执行程序(App.java->run as application),打开浏览器,查看结果

或者地址为:localhost:8080/工程名/文件夹名/html名

四、参考

 

[1]. https://blog.csdn.net/olivezct/article/details/52223051

因为github不支持上传空文件夹,所以项目中有几个空文件夹没push上去。可以自己创建工程,然后将上面自己创建的文件夹拷到相应的位置应该就可以运行

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值