>웹 프론트엔드 >JS 튜토리얼 >매우 간단한 jquery xml ajax 새로 고침이 없는 트리 구조(CSS 없음, 배경은 C#)_jquery

매우 간단한 jquery xml ajax 새로 고침이 없는 트리 구조(CSS 없음, 배경은 C#)_jquery

WBOY
WBOY원래의
2016-05-16 18:25:49962검색
复aze代码 代码如下:

시스템 사용;
System.Collections.Generic 사용;
System.Linq 사용;
System.Web 사용;
System.Web.UI 사용;
System.Web.UI.WebControls 사용;
System.Data.Linq 사용;
System.Xml 사용;
System.Xml.Linq 사용;
namespace WebApplication3 {
public 부분 클래스 WebForm1: System.Web.UI.Page {
protected void Page_Load(object sender, EventArgs e) {
int id = Convert.ToInt32(Request["parentID "]);
GetXML(id);
}
공개 IList < 제품 > GetList() {
새 목록 반환 < 제품 > () {
새 제품() {
Id = 1,
ParentId = 0,
HasChild = 1,
Name = "aaaaa"
},
새 제품 () {
Id = 2,
ParentId = 1,
HasChild = 1,
Name = "bbbb1"
},
new Product() {
Id = 3,
ParentId = 2,
HasChild = 0,
Name = "ccccc2"
},
new Product() {
Id = 4,
ParentId = 2 ,
HasChild = 0,
Name = "ddddd3"
},
new Product() {
Id = 5,
ParentId = 1,
HasChild = 0,
이름 = "eeeeee4"
},
새 제품() {
Id = 6,
ParentId = 3,
HasChild = 0,
이름 = "ffffff5"
},
new Product() {
Id = 7,
ParentId = 4,
HasChild = 0,
Name = "ggggggg6"
},
new Product() {
Id = 8,
ParentId = 7,
HasChild = 0,
Name = "hhhhhhh7"
},
new Product() {
Id = 9,
ParentId = 0,
HasChild = 0,
Name = "jjjjjjj8"
},
new Product() {
Id = 10,
ParentId = 0,
HasChild = 0,
이름 = "yyyyyyyy9"
}
};
} /// <요약>
/// 通过父节点读取子节点并且拼接成xml给前台
///
///
public void GetXML(int parentId) {
List list = GetList().Where(x => x.ParentId == parentId).ToList();
XElement xElement = new XElement("textTree");
foreach(목록의 제품 p) {
xElement.Add(new XElement("value", new XAttribute("id", p.Id),p.Name));
}
xElement.Save("d:\kissnana.xml");
XmlDocument xdocument = new XmlDocument();
xdocument.Load("d:\kissnana.xml");
Response.ContentType = "텍스트/xml";
xdocument.Save(Response.OutputStream);
응답.끝();
}
}
public class Product {
public int Id{set;get;}
public int ParentId{set;get;}
public int HasChild{set;get; }
공용 문자열 이름{set;get;}
}}
思路很简单,后台利用xml送往前台遇过jquery接收处理拼接ul,
li原理(利용 < 리 > 中嵌套 < ul > 적방법,局部读取一节点下的所有直属子节点,每次点击读取,读取过的话,则进入GetDisplayOrNot()방식법判断显示및隐藏节点)html代码: < 본체 >
runat = "서버" > value = "text"
onclick = "LoadXml(0)" / >




前台代码:
复代码 代码如下:



백엔드:
코드 복사 코드는 다음과 같습니다.

using System; System.Collections.Generic 사용;
System.Linq 사용;
System.Web.UI 사용
System.Web.UI.WebControls 사용; .Data.Linq;
System.Xml 사용;
System.Xml.Linq 사용
WebApplication3
{
공개 부분 클래스 WebForm1: System.Web.UI.Page
{
protected void Page_Load(객체 전송자, EventArgs e)
{
int id =Convert.ToInt32(Request["parentID"])
GetXML(id)
}
public IList GetList()
{
return new List ()
{
new Product(){ Id=1, ParentId=0, HasChild=1, Name= "aaaaa" },
새 제품(){ Id=2, ParentId=1, HasChild =1, Name="bbbb1" },
새 제품(){ Id=3, ParentId=2, HasChild= 0, Name="ccccc2" },
새 제품(){ Id=4, ParentId =2, HasChild=0, Name="dddd3" },
새 제품(){ Id=5, ParentId= 1, HasChild=0, Name="eeeeee4" },
새 제품(){ Id =6, ParentId=3, HasChild=0, Name="ffffff5" },
새 제품(){ Id= 7, ParentId=4, HasChild=0, Name="ggggggg6" },
새 제품(){ Id=8, ParentId=7, HasChild=0, Name="hhhhhhh7" },
새 제품( ){ Id=9, ParentId=0, HasChild=0, Name="jjjjjjj8" },
새 제품(){ Id=10,ParentId=0, HasChild=0, Name="yyyyyyyy9" }
};
}

///
/// 상위 노드를 통해 하위 노드를 읽고 프런트 데스크용 XML로 연결합니다.
/// < /summary>///
public void GetXML(int parentId)
{
List .Where(x => x.ParentId == parentId).ToList();
XElement xElement = new XElement("textTree")
foreach(목록의 제품 p)
{
xElement.Add(new XElement("value", new XAttribute("id", p.Id),p.Name ))
}
xElement.Save("d:\kissnana.xml");
XmlDocument xdocument = new XmlDocument();
xdocument.Load("d:\kissnana.xml" )
Response.ContentType = "text/xml"
xdocument.Save(Response. OutputStream);
Response.End();
}
}
공용 클래스 제품
{
공용 int Id{set;get;}
공공 int ParentId{set ;get;}
공용 int HasChild{set;get;}
공용 문자열 이름{set;get ;}
}
}

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.