亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

淺析jQuery EasyUI中的tree使用指南

2019-11-20 13:40:02
字體:
來源:轉載
供稿:網友

  本文記錄的是帶領成員開發一個小模塊功能的時候,需要用到彈出窗口加載樹狀級聯單位選擇,最后決定用采用jQuery+EasyUI插件進行開發。但是在使用EasyUI中tree的插件時,碰到了不少麻煩。為了提供彈出樹的顯示速度,就采用異步加載數節點值,首先先加載根節點,然后根據點擊的節點展開加載子節點。

  往往結果和預期的都不一樣,困惑了幾天,展開后子節點是動態加載了,但是收縮后無法清空之前填充的數據;第二次在展開時,子節點又被重復加載了一遍,造成了數據重復顯示,并沒有提供清除子節點的方法。想盡了各種辦法來解決這個問題,只能換另一種形式加載子節點的值了,把每一個節點值保存起來,判斷是否已經存在,存在就不在去加載。

  兩種方法見實例:

復制代碼 代碼如下:

var treeTitle = '選擇列表';
var treeUrl = '../DataAshx/getTreeNode.ashx?pid=-1';
var nodeExp=false;
var nodekeep="";
var rows;
var noinf=0;
$(function() {
    $('#treewindow').window({
        title: treeTitle,
        width: 400,
        height: 400,
        modal: true,
        shadow: false,
        closed: true,
        resizable: false,
        maximizable: false,
        minimizable: false,
        collapsible: false
    });
});
function treeWindowOpen(name,rowIndx) {
    $('#treewindow').window('open');
    nodekeep="";
    nodeExp=false;
    rows=rowIndx.toString();
    $('#basetree').tree({
        checkbox: true,
        animate: true,
        url: treeUrl+"&coln="+escape(name.toString()),
        cascadeCheck: true,
        onlyLeafCheck: false,
        onBeforeExpand: function(node, param) {
//------------第一種方法:異步加載子節點值-------------
//            $('#basetree').tree('options').url = "../DataAshx/getTreeNode.ashx?pid=" + node.id+"&coln="+escape(name.toString());
//------------第二種方法:Ajax方法返回子節點Json值,使用append方法加載子節點      
        $.ajax({
                type: "POST",
                url: "../DataAshx/getTreeNode.ashx?pid=" + node.id+"&coln="+escape(name.toString())+"&casn="+escape(node.attributes.cas.toString()),
                cache: false,
                async: false,
                dataType: "json",
                success: function(data) {
                    if(nodekeep.indexOf(node.id)==-1)
                    {
                     append(data, node);
                     nodeExp = true;
                    }
                }
            });
            $("#radCollapse").removeAttr("checked");
        },
        onLoadError:function(Error)
        {
            $.messager.alert('提示', '查詢語句出錯', 'error');
            if(nodeExp==false)
            {
                $("#basetree").children().remove();
            }
        },
        onLoadSuccess:function(success)
        {
            var child=$("#basetree").children().length;
            noinf++;
            if(child==0&&noinf>1)
            {
                $.messager.alert('提示', '數據不存在', 'Info');
            }
        }
    });
}
function treeWindowClose() {
    $('#treewindow').window('close');
    nodekeep="";
    nodekeep=false;
}
function treeWindowSubmit() {
    var nodes = $('#basetree').tree('getChecked');
    var info = '';
    if (nodes.length > 0) {
        for (var i = 0; i < nodes.length; i++) {
            if (info != '') { info += ','; }
            info += nodes[i].text;
        }
        //alert(JSON.stringify(nodes));
    }
    else {
        var node = $('#basetree').tree('getSelected');
        if (node != null) {
            info = node.text;               
        }
    }
    $("#"+rows).val(info);
    $('#treewindow').window('close');
    nodekeep="";
    nodeExp=false;
}
//全部展開
function collapseAll() {
    $("#radCollapse").attr("checked", "checked");
    var node = $('#basetree').tree('getSelected');
    if (node) {
        $('#basetree').tree('collapseAll', node.target);
    } else {
        $('#basetree').tree('collapseAll');
    }
}
//全部收縮
function expandAll() {
    var node = $('#basetree').tree('getSelected');
    if (node) {
        $('#basetree').tree('expandAll', node.target);
    } else {
        $('#basetree').tree('expandAll');
    }
}
//增加子節點
function append(datas,cnode) {
    var node = cnode;
    $('#basetree').tree('append', {
        parent: node.target,
        data: datas
    });
    nodekeep+=","+node.id;
}
//重新加載
function reload() {
    var node = $('#basetree').tree('getSelected');
    if (node) {
        $('#basetree').tree('reload', node.target);
    } else {
        $('#basetree').tree('reload');
    }
}
//刪除子節點
function remove() {
    var node = $('#basetree').tree('getSelected');
    $('#basetree').tree('remove',node.target);
}

  頁面getTreeNode.ashx返回樹節點JSON格式數據:

復制代碼 代碼如下:

<%@ WebHandler Language="C#" Class="getTreeNode" %>
using System;
using System.Collections;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;
using System.Collections.Generic;

public class getTreeNode : IHttpHandler, System.Web.SessionState.IRequiresSessionState
{
    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "text/plain";
        DataTable dt = (DataTable)context.Session["viewmaintain"];
        string parentId = string.Empty;
        string resultStr = string.Empty;
        string attributes = string.Empty;
        string colName = string.Empty;
        string sql = string.Empty;
        string Casname = string.Empty;
        bool colt = false;
        string icon = "icon-profile";
        if (!string.IsNullOrEmpty(context.Request.QueryString["pid"]))
        {
            parentId = context.Request.QueryString["pid"].ToString();
        }
        if ((!string.IsNullOrEmpty(context.Request.QueryString["coln"])) && (string.IsNullOrEmpty(context.Request.QueryString["casn"])))
        {
            colName = HttpUtility.UrlDecode(context.Request.QueryString["coln"].ToString());
            if (dt != null)
            {
                bool pt = true;
                while (pt)
                {
                    for (int i = 0; i < dt.Rows.Count; i++)
                    {
                        Casname = dt.Rows[i]["view_colname"].ToString();
                        if (dt.Rows[i]["view_colname"].ToString() == colName)
                        {
                            if (dt.Rows[i]["view_cas"].ToString() != null&&dt.Rows[i]["view_cas"].ToString() !="")
                            {
                                colName = dt.Rows[i]["view_cas"].ToString();
                            }
                            else
                            {
                                colt = true;
                                sql = dt.Rows[i]["view_sql"].ToString();
                                pt = false;
                            }
                            break;
                        }
                    }
                }
            }
        }
        if ((!string.IsNullOrEmpty(context.Request.QueryString["casn"])) && (!string.IsNullOrEmpty(context.Request.QueryString["coln"])))
        {
           string casnName = HttpUtility.UrlDecode(context.Request.QueryString["casn"].ToString());
           colName = HttpUtility.UrlDecode(context.Request.QueryString["coln"].ToString());
            if (dt != null)
            {
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    Casname = dt.Rows[i]["view_colname"].ToString();
                    if (dt.Rows[i]["view_cas"].ToString() == casnName && casnName != colName)
                    {
                        colt = true;
                        sql = dt.Rows[i]["view_sql"].ToString();
                        break;
                    }
                }
            }
        }
        try
        {
            if (parentId != "" && colt == true)
            {
                //此處省略得到數據列表的代碼
                List<TreeInfo> ltree = DAL_TreeInfo.GetItemValue(parentId, sql);
                resultStr = "";
                resultStr += "[";
                if (ltree.Count > 0)
                {
                    foreach (TreeInfo item in ltree)
                    {
                        attributes = "";
                        attributes += "{/"cas/":/"" + Casname;
                        attributes += "/",/"val/":/"" + item._text + "/"}";
                        resultStr += "{";
                        resultStr += string.Format("/"id/": /"{0}/", /"text/": /"{1}/", /"iconCls/": /"{2}/", /"attributes/": {3}, /"state/": /"closed/"", item._id, item._text, icon, attributes);
                        resultStr += "},";
                    }
                    resultStr = resultStr.Substring(0, resultStr.Length - 1);
                }
                resultStr += "]";
            }
            else
            {
                resultStr = "[]";
            }
        }
        catch (Exception ex)
        {
            resultStr = "出錯";
        }
        context.Response.Write(resultStr);
    }
    public bool IsReusable
    {
        get
        {
            return false;
        }
    }
}


 
  關鍵性的代碼都已經在上面了,目前也就只能想到這種辦法來解決了,有時間的話可以給tree擴展一下,添加一個清除子節點的方法,這樣應該實現起來會更容易方便。

  小弟在此獻丑了,不知道各位專家、同仁有沒有遇到類似的問題,或者有其它更好的解決辦法,歡迎在這交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲性无码av在线| 亚洲精品动漫久久久久| 45www国产精品网站| 国产精品视频一| 欧美国产乱视频| 欧美成人精品xxx| 中文字幕视频在线免费欧美日韩综合在线看| 中文字幕亚洲字幕| 亚洲精品日韩欧美| 亚洲www在线| 亚洲黄色免费三级| 久久影视电视剧免费网站| 国模精品视频一区二区| 97色在线观看| 欧美风情在线观看| 国产日产亚洲精品| 久久99视频免费| 欧美性生活大片免费观看网址| 国产精品第三页| 日韩精品中文在线观看| 91国在线精品国内播放| 91综合免费在线| 大胆欧美人体视频| 亚洲精品视频在线播放| 97国产真实伦对白精彩视频8| 久久精品国产v日韩v亚洲| 国产精品一区二区三区毛片淫片| 日韩欧美亚洲国产一区| 欧美亚洲成人精品| 亚洲欧美资源在线| 亚洲无av在线中文字幕| 午夜精品久久久久久久99热浪潮| 欧美另类在线播放| 成人黄色大片在线免费观看| 久久好看免费视频| 欧美性xxxxxx| 亚洲欧美另类在线观看| 欧美中文在线免费| 国产精品久久久久福利| 国产精品91在线观看| 热久久美女精品天天吊色| 精品成人久久av| 亚洲国产天堂网精品网站| 日韩欧美第一页| 中文字幕日韩欧美在线视频| 亚洲视频在线观看视频| 久久久www成人免费精品张筱雨| 亚洲精品国产拍免费91在线| 欧美另类高清videos| 国语自产精品视频在免费| 国产精品va在线播放| 国产狼人综合免费视频| 欧美日本高清一区| 亚洲国产精品va在线看黑人动漫| 高清欧美电影在线| 日本久久精品视频| 成人国产精品色哟哟| 91在线国产电影| 欧美色播在线播放| 色偷偷av一区二区三区乱| 欧美日本在线视频中文字字幕| 亚洲精品美女在线观看播放| 欧美日韩国产黄| 国产精品视频男人的天堂| 亚洲va码欧洲m码| 欧美日韩国产中文精品字幕自在自线| 日韩二区三区在线| 亚洲色图校园春色| 久久av资源网站| 国产精品爽爽爽爽爽爽在线观看| 4438全国亚洲精品在线观看视频| 久久免费精品视频| 亚洲福利影片在线| 国内精品美女av在线播放| 欧美精品国产精品日韩精品| 91精品视频专区| 久久婷婷国产麻豆91天堂| 国产97色在线| 亚洲第一福利在线观看| 亚洲一区二区黄| 欧美日韩美女在线观看| 国产精品爽爽ⅴa在线观看| 国产精品久久二区| 日韩av电影在线播放| …久久精品99久久香蕉国产| 欧美激情中文字幕乱码免费| 欧美一级片在线播放| 午夜精品一区二区三区在线视| 欧美成人手机在线| 亚洲成色777777在线观看影院| 91在线免费视频| 色婷婷**av毛片一区| 日本精品久久久久久久| 午夜免费在线观看精品视频| 日韩av电影在线播放| 日韩精品视频在线观看免费| 欧美激情一级欧美精品| 亚洲成色www8888| 综合国产在线观看| 日本久久91av| 国产欧美一区二区白浆黑人| 欧美日韩一区二区三区在线免费观看| 91啪国产在线| 亚洲国产精品专区久久| 中文字幕亚洲综合| 亚洲成人黄色网址| 亚洲日韩第一页| 在线一区二区日韩| 久久久久久久久久久免费| 成人福利视频网| 国产视频精品xxxx| 欧美韩日一区二区| 欧美日韩性视频在线| 国产99久久精品一区二区 夜夜躁日日躁| 国产日韩精品一区二区| 大伊人狠狠躁夜夜躁av一区| 精品调教chinesegay| 精品毛片网大全| 欧美性xxxx| 成人免费视频在线观看超级碰| 国产精品夫妻激情| 国产精品久久久久久久久久久久久| 亚洲剧情一区二区| 91精品久久久久久久久不口人| 亚洲在线观看视频网站| 亚洲精品久久久久久下一站| 欧美黑人巨大精品一区二区| 国产精品美乳一区二区免费| 国产成人精品免高潮费视频| 欧美精品18videos性欧美| 亚洲精品欧美极品| 欧美成人午夜激情视频| 4444欧美成人kkkk| www.日本久久久久com.| 国产成人精品视频在线| 亚洲欧美在线x视频| 91精品国产综合久久久久久蜜臀| 疯狂欧美牲乱大交777| 91精品久久久久久久久久入口| 欧美成人免费全部| 欧美日韩一区二区在线播放| 国产美女精品免费电影| 91视频免费网站| 日韩在线观看免费高清| 欧美成年人在线观看| 国产丝袜精品第一页| 久久亚洲电影天堂| 国产日韩精品入口| 69久久夜色精品国产69乱青草| 日韩精品日韩在线观看| 国产亚洲成av人片在线观看桃| 国产在线精品播放| 国产精品视频一区二区三区四| 亚洲精品久久久久久久久久久久| 成人国产亚洲精品a区天堂华泰| 国产精品视频在线播放| 国内精品久久久久影院优| 久久久久五月天| 国产91精品黑色丝袜高跟鞋| 91人人爽人人爽人人精88v| 欧美国产日产韩国视频| 久久亚洲成人精品| 欧美国产日韩精品| 国产精品99久久久久久久久久久久|