찾다
백엔드 개발XML/RSS 튜토리얼XML은 정렬 가능하고 페이지가 매겨진 데이터 표시 페이지를 생성합니다.

웹 개발 시 페이징 표시 및 데이터 레코드 세트 정렬을 자주 접하게 되는데, 이는 asp, php, jsp 등과 같은 서버 측 코드 및 데이터베이스 기술을 사용하여 서버 측에서 수행하는 것이 매우 쉽습니다. 그러나 클라이언트에 여러 레코드를 표시하고 정렬하려는 경우 머리가 아플 수 있습니다. 아래에서는 Extensible Markup Language(xml, extensible markup Language)와 Extensible Stylesheet Language Transformations(XSLT, extensible style Single Language Transformation)을 XML Path Language(XPath, XML path Language)와 결합하여 사용하고, 간단한 코드만 작성하면 되며, 쉽게 달성할 수 있습니다. 이 방법을 사용하면 서버를 자주 처리하는 과정을 피하고, 데이터 표시 시간을 절약할 수 있으며, 시청자가 기다리지 않고 결과를 볼 수 있어 서버의 부하도 줄일 수 있습니다. 게다가. XML과 XSLT 기술 덕분에 데이터 저장과 데이터 표시가 분리되고 우리 코드를 재사용할 수 있어 프로그래머의 코드 작성 부담이 크게 줄어듭니다.
아래에서는 기능을 단계별로 구현해보겠습니다.

첫 번째: XSLT 만들기

XSLT 스타일 시트의 첫 번째 줄은 XML이 준수하는 XML 사양 버전을 나타내고, 다음으로 스타일 시트에서 사용하는 네임스페이스를 나타냅니다. XSL 사양 XSL의 초안 작성 방법을 사용하는 대신 XSL의 공식 버전을 작성하려면:

   <xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">

참고: 둘 사이에는 기능과 작성 방법에 큰 차이가 있습니다.

 <?xml version="1.0"?>  
   <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

다음으로 XSLT에서 템플릿 태그를 정의합니다.

<xsl:template match="/">  
   <xsl:apply-templates select="/客户关系表"/>  
   </xsl:template>  
    
   <xsl:template match="/客户关系表"></xsl:template>


템플릿에 표시할 스타일을 작성합니다. 우리는 HTML 데이터 아일랜드를 사용하여 데이터를 저장합니다. 이러한 데이터는 SQL Server 2000의 XML 쿼리를 사용하여 얻을 수 있습니다. XML을 지원하지 않는 데이터베이스의 경우 자체 구성 요소를 작성하여 데이터를 XML 형식으로 변환한 다음 저장할 수 있습니다. 데이터 섬 내부. HTML에서 데이터 아일랜드를 사용하는 방법에는 두 가지가 있습니다.
하나는 아래와 같이 데이터를 직접 삽입하는 것입니다.

 <XML id=&#39;&#39;Data&#39;&#39;>  
   <客户关系表>  
   <客户>每条数据</客户>  
   </客户关系表>  
   </XML>

다른 하나는 아래와 같이 SRC 속성을 통해 외부 파일을 참조하는 것입니다.

 <XML id=&#39;&#39;Data&#39;&#39; src=&#39;&#39;Data.xml&#39;&#39;></XML>

데이터 아일랜드에 있는 데이터를 사용하려면 ID 이름을 통해 참조해야 합니다. 물론 XSLT 파일도 일종의 XML 형식 파일이므로 이 방법을 통해서도 얻을 수 있습니다. :

<XML id=&#39;&#39;Style&#39;&#39; src=&#39;&#39;Style.xsl&#39;&#39;></XML>

페이지에 마크업 DIV를 추가하여 변환 결과를 표시합니다.

   <div id="DisplayArea"></div>


XSLT를 사용하여 데이터 아일랜드의 데이터를 변환합니다. DOMDocument의 transNode() 메서드를 사용하고 결과를 변환합니다. DIV의 innerHTML 속성을 통해 표시됩니다.

DisplayArea.innerHTML = Data.transformNode(Style.DocumentElement)

2단계: 클라이언트측 정렬 기능 구현

먼저 기본 정렬 필드를 설정하고 여기에서 "일련 번호"를 기본 정렬 키워드로 선택하고 오름차순으로 정렬한 다음 XSLT에 정렬 태그를 추가합니다.

<xsl:for-each select="客户">  
   <xsl:sort select="序号" order="descending" data-type="number"/>  
   </xsl:for-each>

다음으로 스타일에 정렬 기능을 추가합니다. 사용자 작업에 응답할 수 있도록 시트에 sort() 함수를 호출하는 테이블 헤더의 각 열에 onClick 이벤트를 추가하여 사용자가 테이블 헤더를 클릭하여 열을 정렬할 수 있도록 했습니다.

  <td onClick="sort(&#39;&#39;序号&#39;&#39;)">序号</td>  
   Sort()函数的语句如下所示:  
   Function Sort(strField)  
    
   Dim sortField  
   Dim sortOrderAttribute  
    
   &#39;&#39; 得到原来排序字段的属性值  
   Set sortField = Style.XMLDocument.selectSingleNode("//xsl:sort/@select")  
    
   &#39;&#39; 得到原来排序的顺序属性值  
   Set sortOrderAttribute = Style.XMLDocument.selectSingleNode("//xsl:sort/@order")  
    
   &#39;&#39; 如果我们已经按所点击的列的字段排序,我们必须改变排序的顺序;  
   &#39;&#39; 否则,我们只需要按新所点击的列字段按默认的顺序进行排序  
   If sortField.Value = strField Or sortField.Value = "./*[0]" Then  
   If sortOrderAttribute.Value = "descending" Then  
   sortOrderAttribute.Value = "ascending"  
   Else  
   sortOrderAttribute.Value = "descending"  
   End If  
   Else  
   sortField.Value = strField  
   sortOrderAttribute.Value = "ascending"  
   End If  
    
   Set sortField = Nothing  
   Set sortOrderAttribute = Nothing  
   &#39;&#39; 输出排序后的结果  
   DisplayArea.innerHTML = Data.transformNode(Style.DocumentElement)  
    
   End Function

다음으로 각 페이지의 레코드 수를 표시하고 이전 페이지와 다음 페이지를 설정하는 기능을 구현합니다. 스팬 태그를 사용하면 현재 표시된 페이지, 총 페이지 수, 총 레코드 수를 표시할 수 있습니다. 기본적으로 페이지당 6개의 레코드를 표시하고 intRecordsPerPage 변수를 사용하여 이 값을 저장합니다.

<table width="100%" border="0" style="font-size:9pt">  
   <tr>  
   <td align="left"><b>第 <span id="CurrentPage"></span> 页 总 <span id="PageCount"></span> 页    共有 <span id="RecordCount"></span> 条记录</b></td>  
   <td align="right"><b>每页记录数:<input onblur="setRecordsPerPage()" id="RecordsPerPage" style="vertical-align:middle;height:15pt;width:30px"/></b></td>  
   <td align="right">  
   <span id="Paging">  
   <input type="button" OnClick="FirstPage()" value="第一页"/>  
   <input type="button" OnClick="PReviousPage(1)" value="上一页"/>  
   <input type="button" OnClick="nextPage(1)" value="下一页"/>  
   <input type="button" OnClick="LastPage()" value="最末页"/>  
   </span>  
   </td>  
   </tr>  
   </table>

다음은 "다음 페이지" 버튼으로 수행되는 작업을 예로 들어 다양한 페이지를 변환하는 과정을 보여줍니다. . 이 함수는 intPage 매개변수를 기반으로 표시할 레코드 수와 해당 페이지를 결정합니다. 각 버튼의 값 값은 XSL DOM의 콘텐츠를 동적으로 변경하여 이루어집니다.

Function nextPage(intPage)  
    
   Dim strDisplay  
   Dim strDateRange  
    
   If CInt(CStr(intPage) * intRecordsPerPage) < _  
   Data.selectNodes("/客户关系表/客户").length Then  
   intPage = CInt(intPage) + 1  
    
   Style.XMLDocument.selectNodes("//@OnClick") _  
   (1).Value = "previousPage(" & intPage & ")"  
    
   Style.XMLDocument.selectNodes("//@OnClick") _  
   (2).Value = "nextPage(" & intPage & ")"  
    
   Style.XMLDocument.selectNodes _  
   ("//xsl:for-each/@select")(1).Value = _  
   "./客户[position() <= " & (CStr(intPage) _  
   * intRecordsPerPage) & " and position() > " _  
   & (CInt(intPage) - 1) * intRecordsPerPage & _  
   "]"  
    
   redisplay (intPage)  
    
   End If  
    
   End Function

下面,我们来看看设置每个页面记录条数的函数setRecordsPerPage(),该函数通过动态修改xsl:for-each的select属性值来实现的,使用XPath来遍历那些符合节点位置大于0并且节点位置小于每页记录数加1的那些节点。其中主要的语句是下面的一行:  
   Style.XMLDocument.selectNodes("//xsl:for-each/@select")(1). _  
   value = "./客户[position()  0]"  
   到目前为止,我们的页面既可以实现排序,也实现动态改变每页显示记录条数的功能了,为了实现可重用的要求,我们还可以进行进一步的改进。XPath是进行XML/XSLT应用开发的一个强有力的工具,XPath中可以使用通配符,使XSLT样式单文件完全不依赖于你的数据节点名称。因此,我们在改变XML数据的时候,只要不改变节点的层次关系,可以不必改动XSLT就可以直接使用。比如:在本例中,你可以添加或者删除某些字段、或添加删除一些记录,直接使用本例中的XSLT,不但可以在表格里正常显示出数据,而且还能正常排序和分页。  
   下面我们就分析一下是如何实现的。比如下面的层次关系:  

 <客户关系表>  
   <客户>  
   <序号></序号>  
   <姓名></姓名>  
   <电子邮件></电子邮件>  
   </客户>  
   </客户关系表>

   假如我们的XSLT中有这样一个选择模板的句子:  

<xsl:apply-templates select="/客户关系表"/>

   为了实现通用性的要求,我们可以使用通配符:  

  <xsl:apply-templates select="/*"/>

 这里我们使用了子运算符"/",它选择了根下的所有节点,两者的不同点在于:"/客户关系表"选择的是根下的客户关系表子节点,而"/*"选择的是根下所有的直接子节点,在上面的XML数据格式中,二者是完全等价的。  
   对于下面的for-each循环来说:

<xsl:for-each select="客户">  
   <xsl:sort select="序号" order="ascending"/>  
   </xsl:for-each>

   我们可以改变成这样的形式:  

  <xsl:for-each select="./*">  
   <xsl:sort select="./*[1]" order="ascending"/>  
   </xsl:for-each>

这里"./*"表示你应当包含进去当前节点下所有的一级子节点,语法"./*[1]"表示的是选择当前节点中的第一个子节点。  
   另外还有一个地方可以改进的是,我们可以把它改成,表示在每一次循环中选择当前节点。  
   在我们的函数中,还使用了一些硬代码,如果不做改动的话,我们的通用性还是实现不了,因此,我们下面就看看如何替换硬代码中的语句。  
   在创建表头的时候,我们使用了

 序号的语句,如果XML数据里没有序号节点的话,这里显然会出现错误的,为了实现通用性,我们自定义了一个函数getName,来取得所要显示的节点的名称:  
<td>  
   <xsl:attribute name="onClick">  
   Sort(&#39;&#39;<xsl:value-of select="user:getName(.)"/>&#39;&#39;)  
   </xsl:attribute>  
   <xsl:value-of select="user:getName(.)"/>  
   </td>

 自定义函数是XSLT的一个突出的功能,要使用这个特性,我们得用msxml:script元素来定义,同时,必须在样式单定义的时候指定一个用户定义的名字空间。下面就是我们使用自定义函数的全部内容:  

 <xsl:stylesheet xmlns:xsl=http://www.w3.org/1999/XSL/Transform  
   xmlns:msxsl="urn:schemas-microsoft-com:xslt"  
   xmlns:user="http://lucky.myrice.com"  
   version="1.0">  
   <msxsl:script language="VBScript" implements-prefix="user">  
   <![CDATA[  
   function getName(node)  
   getName = node.item(0).nodeName  
   end function  
   }>  
   </msxsl:script>

在我们的XSLT文件中,使用了两个循环,我们分别进行相应的更改,第一处:显示表头的地方改为,它等同于;第二处循环是显示每行记录,改成。还有其他的地方需要更改的,请参见后面的完整源代码部分。这样我们就完成了通用的XSLT文件,不管你的XML数据有多少字段,也不管节点名称是什么,我们都无需更改XSLT文件,就可以实现我们的功能了。最终的浏览效果将会象下图所示:  

XML은 정렬 가능하고 페이지가 매겨진 데이터 표시 페이지를 생성합니다.

   以下是完整的Style.xsl文件的内容:  

  
     
     
     
     
    
     
   <xsl:apply-templates select="/*"/>  
     
    
     
   
页 总 页 共有 条记录 每页记录数:
Sort('''')
以下是进行输出的Exam.htm文件:

客户关系表

<客户关系表 xmlns:dt="urn:schemas-microsoft-com:datatypes"> <客户><序号 dt:dt="int">01<姓名>Mi<电子邮件>water@21cn.com <客户><序号 dt:dt="int">02<姓名>uyi<电子邮件>Lily@sina.com <客户><序号 dt:dt="int">03<姓名>uiyu<电子邮件>John@21cn.com <客户><序号 dt:dt="int">04<姓名>Doug<电子邮件>Karry@163.net <客户><序号 dt:dt="int">05<姓名>Ellen<电子邮件>vivki@sina.com <客户><序号 dt:dt="int">06<姓名>Frank<电子邮件>net_lover@mengxianhui.com.cn <客户><序号 dt:dt="int">07<姓名>Greg<电子邮件>meng@mengxianhui.com <客户><序号 dt:dt="int">08<姓名>Harry<电子邮件>sunny@xianhui.net <客户><序号 dt:dt="int">09<姓名>Ingrid<电子邮件>cathy@hotmail.com <客户><序号 dt:dt="int">10<姓名>Jeff<电子邮件>your@mxh.com <客户><序号 dt:dt="int">11<姓名>Kelly<电子邮件>Iloveyou@mengxianhui.com <客户><序号 dt:dt="int">12<姓名>Larry<电子邮件>smilling@mengxianhui.com <客户><序号 dt:dt="int">13<姓名>Mark<电子邮件>money@21cn.com <客户><序号 dt:dt="int">14<姓名>Nancy<电子邮件>www@yahoo.com <客户><序号 dt:dt="int">15<姓名>Peter<电子邮件>dotnet@aol.com <客户><序号 dt:dt="int">16<姓名>Rachel<电子邮件>billgates@microsoft.com <客户><序号 dt:dt="int">17<姓名>Seth<电子邮件>flying@yous.net <客户><序号 dt:dt="int">18<姓名>Tim<电子邮件>agooyboy@lovegirl.com <XML id=&#39;&#39;Style&#39;&#39; src=&#39;&#39;Style.xsl&#39;&#39;></XML> <div id="DisplayArea"></div>
资料来源:【孟宪会之精彩世界

   把上面的内容拷贝到本地计算机上,分别保存为相应的文件,在IE5+和XML3.0+的环境下即可看到效果! 

 以上就是XML创建可排序、分页的数据显示页面的内容,更多相关内容请关注PHP中文网(www.php.cn)!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
잘 형성된 XML 마스터 링 : 데이터 교환을위한 모범 사례잘 형성된 XML 마스터 링 : 데이터 교환을위한 모범 사례May 14, 2025 am 12:05 AM

wformedxmliscrucialfordataexchangebecauseItensurescorrectparsingand and underdestandingAcrosssystems.1) 시작된 경사 같은 곳에서 시작합니다

XML : 아직도 사용됩니까?XML : 아직도 사용됩니까?May 13, 2025 pm 03:13 PM

xmlisstillusedduetoitsstructurednature, HumanReadability 및 WideSpreadAdoptioninenterPriseEnvironments.1) ItfacilitatesDataExChangeInsectorsikeFinance (SWIFT) 및 HL7) .2) ITSHUMAN-ReadableFormataIdSinmanualDatainsPectioning.3) XMLISERDEN

RSS 문서의 해부학 : 구조 및 요소RSS 문서의 해부학 : 구조 및 요소May 10, 2025 am 12:23 AM

RSS 문서의 구조에는 세 가지 주요 요소가 포함됩니다 : 1. : RSS 버전 정의 루트 요소; 2. : 제목, 링크 및 설명과 같은 채널 정보를 포함합니다. 3. : 제목, 링크, 설명 등을 포함한 특정 콘텐츠 항목을 나타냅니다.

RSS 문서 이해 : 포괄적 인 가이드RSS 문서 이해 : 포괄적 인 가이드May 09, 2025 am 12:15 AM

RSS 문서는 XML 파일을 통해 컨텐츠 업데이트를 게시하는 간단한 구독 메커니즘입니다. 1. RSS 문서 구조는 여러 요소로 구성되며 요소를 포함합니다. 2. RSS 리더를 사용하여 XML을 구문 분석하여 채널을 구독하고 정보를 추출하십시오. 3. 고급 사용에는 FeedParser 라이브러리를 사용한 필터링 및 정렬이 포함됩니다. 4. 일반적인 오류에는 XML 구문 분석 및 인코딩 문제가 포함됩니다. XML 형식 및 인코딩은 디버깅 중에 확인해야합니다. 5. 성능 최적화 제안에는 캐시 RSS 문서 및 비동기 구문 분석이 포함됩니다.

RSS, XML 및 최신 웹 : 콘텐츠 신디케이션 깊은 다이빙RSS, XML 및 최신 웹 : 콘텐츠 신디케이션 깊은 다이빙May 08, 2025 am 12:14 AM

RSS와 XML은 여전히 ​​최신 웹에서 중요합니다. 1.RSS는 콘텐츠를 게시하고 배포하는 데 사용되며 사용자는 RSS 리더를 통해 구독하고 업데이트를받을 수 있습니다. 2. XML은 마크 업 언어이며 데이터 저장 및 교환을 지원하며 RSS 파일은 XML을 기반으로합니다.

Beyond Basic : XML이 활성화 한 고급 RSS 기능Beyond Basic : XML이 활성화 한 고급 RSS 기능May 07, 2025 am 12:12 AM

RSS를 사용하면 멀티미디어 컨텐츠 임베딩, 조건부 가입 및 성능 및 보안 최적화가 가능합니다. 1) 태그를 통해 오디오 및 비디오와 같은 멀티미디어 컨텐츠를 포함합니다. 2) XML 네임 스페이스를 사용하여 조건부 가입을 구현하여 구독자가 특정 조건에 따라 컨텐츠를 필터링 할 수 있습니다. 3) CDATA 섹션 및 XMLSCHEMA를 통해 RSSFEED의 성능 및 보안을 최적화하여 표준에 대한 안정성과 준수를 보장합니다.

RSS 디코딩 : 웹 개발자를위한 XML 프라이머RSS 디코딩 : 웹 개발자를위한 XML 프라이머May 06, 2025 am 12:05 AM

RSS는 자주 업데이트되는 데이터를 게시하는 데 사용되는 XML 기반 형식입니다. 웹 개발자로서 RSS를 이해하면 콘텐츠 집계 및 자동화 업데이트 기능을 향상시킬 수 있습니다. RSS 구조, 구문 분석 및 생성 방법을 학습하면 RSSFeeds를 자신있게 처리하고 웹 개발 기술을 최적화 할 수 있습니다.

JSON 대 XML : RSS가 XML을 선택한 이유JSON 대 XML : RSS가 XML을 선택한 이유May 05, 2025 am 12:01 AM

RSS는 다음과 같이 JSON 대신 XML을 선택했습니다. 1) XML의 구조 및 검증 기능은 JSON보다 낫습니다. 이는 RSS 복잡한 데이터 구조의 요구에 적합합니다. 2) XML은 당시 광범위하게 지원되었다. 3) RSS의 초기 버전은 XML을 기반으로했으며 표준이되었습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음