如何从后台拼接json(tree)字符串,给jstree赋值
2016-03-15 15:44
633 查看
public object ListMenu(DataTable _list)
{
StringBuilder sb = new StringBuilder();
DataRow[] rows = _list.Select("PID=0");
sb.Append("[");
bool isFist = false;
foreach (DataRow dr in rows)
{
if (isFist)
sb.Append(",");
isFist = true;
string id = dr["ID"].ToString();
sb.Append("{");
sb.AppendFormat("\"id\":\"{0}\",", dr["ID"]);
sb.AppendFormat("\"text\":\"{0}\",", dr["Name"]);
sb.AppendFormat("\"pid\":\"{0}\",", dr["PID"]);
string submenu = GetSubMenu(id, _list);
if (submenu == "")
{
sb.AppendFormat("\"leaf\":\"{0}\",", "true");
sb.Append("\"children\":[");
}
else
{
sb.AppendFormat("\"expanded\":\"{0}\",", "true");
sb.Append("\"children\":[");
sb.Append(submenu);
}
sb.Append("]");
sb.Append("}");
}
sb.Append("]");
_menu = sb.ToString();
return _menu;
}
private string GetSubMenu(string pid, DataTable dt)
{
StringBuilder sb = new StringBuilder();
DataRow[] rows = dt.Select("PID=" + pid);
if (rows.Length > 0)
{
bool isFist = false;
foreach (DataRow dr in rows)
{
if (isFist)
sb.Append(",");
isFist = true;
string id = dr["ID"].ToString();
sb.Append("{");
sb.AppendFormat("\"id\":\"{0}\",", dr["ID"]);
sb.AppendFormat("\"text\":\"{0}\",", dr["Name"]);
sb.AppendFormat("\"pid\":\"{0}\",", dr["PID"]);
string submenu = GetSubMenu(id,dt);
if (submenu == "")
{
sb.AppendFormat("\"leaf\":\"{0}\",", "true");
sb.Append("\"children\":[");
}
else
{
sb.AppendFormat("\"expanded\":\"{0}\",", "true");
sb.Append("\"children\":[");
sb.Append(submenu);
}
sb.Append("]");
sb.Append("}");
}
}
return sb.ToString();
}
可根据实际情况修改相应的值:如children可能是nodes
{
StringBuilder sb = new StringBuilder();
DataRow[] rows = _list.Select("PID=0");
sb.Append("[");
bool isFist = false;
foreach (DataRow dr in rows)
{
if (isFist)
sb.Append(",");
isFist = true;
string id = dr["ID"].ToString();
sb.Append("{");
sb.AppendFormat("\"id\":\"{0}\",", dr["ID"]);
sb.AppendFormat("\"text\":\"{0}\",", dr["Name"]);
sb.AppendFormat("\"pid\":\"{0}\",", dr["PID"]);
string submenu = GetSubMenu(id, _list);
if (submenu == "")
{
sb.AppendFormat("\"leaf\":\"{0}\",", "true");
sb.Append("\"children\":[");
}
else
{
sb.AppendFormat("\"expanded\":\"{0}\",", "true");
sb.Append("\"children\":[");
sb.Append(submenu);
}
sb.Append("]");
sb.Append("}");
}
sb.Append("]");
_menu = sb.ToString();
return _menu;
}
private string GetSubMenu(string pid, DataTable dt)
{
StringBuilder sb = new StringBuilder();
DataRow[] rows = dt.Select("PID=" + pid);
if (rows.Length > 0)
{
bool isFist = false;
foreach (DataRow dr in rows)
{
if (isFist)
sb.Append(",");
isFist = true;
string id = dr["ID"].ToString();
sb.Append("{");
sb.AppendFormat("\"id\":\"{0}\",", dr["ID"]);
sb.AppendFormat("\"text\":\"{0}\",", dr["Name"]);
sb.AppendFormat("\"pid\":\"{0}\",", dr["PID"]);
string submenu = GetSubMenu(id,dt);
if (submenu == "")
{
sb.AppendFormat("\"leaf\":\"{0}\",", "true");
sb.Append("\"children\":[");
}
else
{
sb.AppendFormat("\"expanded\":\"{0}\",", "true");
sb.Append("\"children\":[");
sb.Append(submenu);
}
sb.Append("]");
sb.Append("}");
}
}
return sb.ToString();
}
可根据实际情况修改相应的值:如children可能是nodes
相关文章推荐
- JS eval()函数
- js 数组排序
- JSON解析
- JS获取某年某月的最后一天
- JS中String的高级操作
- js cookie操作
- 在将对象数组转换为json字符串
- servlet向jsp发送的数据出现乱码的解决方法
- JS获取上传文件的大小,更改时间,名称
- FastJSON 解析处理
- 关于JS的算法
- <你不知道的JavaScript>读书笔记
- JS正则表达式验证账号、手机号、电话和邮箱
- js自制广告轮显效果(兼容ie6)
- javascript 常用方法
- 用JS判断一个html元素是否存在的五种方法
- json格式数据的请求处理
- JS中 window的用法
- javascript 数组 去重
- javascript笔记2-value与innerHTML区别