Cet article rapporte que lorsqu'ils ont amené les membres à développer une petite fonction de module, ils ont dû utiliser des fenêtres contextuelles pour charger des sélections d'unités en cascade de type arborescent, et ont finalement décidé d'utiliser le plug-in jQuery EasyUI pour le développement. Cependant, j'ai rencontré beaucoup de problèmes lors de l'utilisation du plug-in d'arborescence dans EasyUI. Afin d'améliorer la vitesse d'affichage de l'arborescence contextuelle, nous utilisons le chargement asynchrone des valeurs des nœuds. Tout d'abord, le nœud racine est chargé, puis les nœuds enfants sont chargés en fonction du nœud cliqué.
Souvent, les résultats sont différents de ce qui était attendu. J'ai été confus pendant quelques jours. Après l'expansion, les nœuds enfants sont chargés dynamiquement, mais après la réduction, les données précédemment remplies ne peuvent pas être effacées lors de la deuxième expansion ; , les nœuds enfants sont à nouveau chargés. Une fois de plus, les données sont affichées à plusieurs reprises et il n'existe aucune méthode pour effacer les nœuds enfants. Après avoir essayé différentes manières de résoudre ce problème, nous ne pouvons charger les valeurs des nœuds enfants que sous une autre forme. Enregistrez chaque valeur de nœud et déterminez si elle existe déjà, chargez-la sans la charger.
Voir des exemples pour deux méthodes :
页面getTreeNode.ashx返回树节点JSON格式数据:
Classe publique getTreeNode : IHttpHandler, System.Web.SessionState.IRequiresSessionState
{
public void ProcessRequest (contexte HttpContext)
{
context.Response.ContentType = "text/plain";
DataTable dt = (DataTable)context.Session["viewmaintain"];
string parentId = string.Empty;
string resultStr = string.Empty;
attributs de chaîne = string.Empty;
string colName = string.Empty;
string sql = string.Empty;
string Casname = string.Empty;
bool colt = faux ;
string icon = "icône-profil";
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());
si (dt != null)
{
bool pt = vrai ;
tandis que (pt)
{
pour (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();
>
d'autre
{
poulain = vrai ;
sql = dt.Rows[i]["view_sql"].ToString();
pt = faux ;
>
pause;
>
>
>
>
>
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());
si (dt != null)
{
pour (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)
{
poulain = vrai ;
sql = dt.Rows[i]["view_sql"].ToString();
pause;
>
>
>
>
essayez
{
if (parentId != "" && colt == true)
{
//此处省略得到数据列表的代码
Liste
resultStr = "";
resultStr = "[";
si (ltree.Count > 0)
{
foreach (élément TreeInfo dans ltree)
{
attributs = "";
attributs = "{"cas": "" Casname;
attributs = "","val":"" item._text ""}";
resultStr = "{";
resultStr = string.Format(""id": "{0}", "text": "{1}", "iconCls": "{2}", "attributs": {3}, "state": " fermé"", item._id, item._text, icône, attributs);
resultStr = "},";
>
resultStr = resultStr.Substring(0, resultStr.Length - 1);
>
resultStr = "]";
>
d'autre
{
resultStr = "[]";
>
>
attraper (Exception ex)
{
resultStr = "出错";
>
contexte.Response.Write(resultStr);
>
public bool est réutilisable
{
obtenir
{
retourner faux ;
>
>
>
小弟在此献丑了,不知道各位专家、同仁有没有遇到类似的问题,或者有其它更好的解决办法,欢迎在这交流。