JSP combined XML + XSLT converts the output to HTML format 2

xiaoxiao2021-03-06  43

Our approach is:

<% @ Taglib Uri = "xsl.jar" prefix = "xsl"%>

For the Apply.jsp coming with Jakarta's XSL Taglib as an example, let's take a look at the relationship between JSP XML XSLT: Apply.jsp

<% @ Taglib Uri = "xsl.jar" prefix = "xsl"%> Employee list </ title> </ head> <body bgcolor = "white"> <p> below The four combinations of JSP XML XSLT: <p> Using the Apply method below, combine the existing Employees.xml and Employeelist.xsl <XSL: Apply XML = "/ XML / EMPLOYEES.XML" XSL = " / xml/employeelist.xsl "/> <hr> <p> below is to write XML data directly using already existing Employeelist.xs, then yourself in JSP. <XSL: Apply XSL =" / XML / EMPLOEELIST.XSL "> < XML Version = "1.0" encoding = "ISO-8859-1"?> <Employees> <Employee ID = "123"> <first-name> john </ first-name> <last-name> doe </ last -Name> <telephone> 800-555-1212 </ telephone> </ employee> <Employee ID = "456> <first-name> jane </ first-name> <last-name> smith </ last-name > <Telephone> 888-555-1212 </ telephone> </ employee> <Employee ID = "789> <first-name> George </ first-name> <last-name> Taylor </ last-name> < TELEPHONE> 555-555-1212 </ telephone> </ EMPLOYEE> </ Employees> </ xsl: apply> <hr> <p> The following to the use of include, such an XSLT style can accommodate different XML files.</p> <p><XSL: Apply XSL = "/ XML / Employeelist.xsl"> <xsl: include page = "/ xml / employees.xml" /> </ xsl: apply> <hr> <p> below is using the Import method, Page-scope Import XML file </ p> <xsl: import id = "data" page = "/ xml / employees.xml =" data "xsl = "/ XML / Employeelist.xsl" /> </ body> In the above program, four JSP combined XML XSLT methods can basically meet our needs. Note The above XML file path is "/ xml /", which is an absolute path to the Tomcat container.</p> <p>Let's take a look at Employeelist.xsl and Employees.xml content:</p> <p>EmployeeList.xsl is similar to CSS in HTML, mainly to define data display mode in XML:</p> <p><? XML Version = "1.0"?> <Xsl: stylesheet version = "1.0" xmlns: xsl = "http://www.w3.org/1999/xsl/transform"> <xsl: template match = "EMPLOYEES" > <Table Border = "1" Width = "100%"> <Tr> <TH> Id </ th> <TH> Employee Name </ TH> <TH> Phone Number </ th> </ TR> <XSL : for-each select = "employee"> <tr> <td> <xsl: value-of select = "@ id" /> </ td> <td> <xsl: value-of select = "last-name" />, <Xsl: value-of select = "first-name" /> </ td> <td> <xsl: value-of select = "telephone" /> </ td> </ tr> </ xsl: For-Each> </ table> </ xsl: test> </ xsl: stylesheet> Employees.xml <? XML Version = "1.0" encoding = "ISO-8859-1"> <Employees> <Employee ID = " 123> <first-name> John </ first-name> <last-name> doe </ last-name> <telephone> 800-555-1212 </ telephone> </ EMPLOYEE> <Employee ID = "456" > <First-name> Jane </ first-name> <last-name> smith </ last-name> <telephone> 888-555-1212 </ telephone> </ employee> <Employee ID = "789> < First-Name> George <</p> <p>/ first-name> <last-name> Taylor </ last-name> <Telephone> 555-555-1212 </ telephone> </ EMPLOYEE> </ EMPLOYEES> If we join at the top of Employees.xml:</p> <p><? Xml: stylesheet type = "text / xsl" href = "catalog.xsl"?></p> <p>Use the browser that supports XML IE 5.0 or above, the display page is the same as the Apply.jsp display page.</p></div><div class="text-center mt-3 text-grey"> 转载请注明原文地址:https://www.9cbs.com/read-86173.html</div><div class="plugin d-flex justify-content-center mt-3"></div><hr><div class="row"><div class="col-lg-12 text-muted mt-2"><i class="icon-tags mr-2"></i><span class="badge border border-secondary mr-2"><h2 class="h6 mb-0 small"><a class="text-secondary" href="tag-2.html">9cbs</a></h2></span></div></div></div></div><div class="card card-postlist border-white shadow"><div class="card-body"><div class="card-title"><div class="d-flex justify-content-between"><div><b>New Post</b>(<span class="posts">0</span>) </div><div></div></div></div><ul class="postlist list-unstyled"> </ul></div></div><div class="d-none threadlist"><input type="checkbox" name="modtid" value="86173" checked /></div></div></div></div></div><footer class="text-muted small bg-dark py-4 mt-3" id="footer"><div class="container"><div class="row"><div class="col">CopyRight © 2020 All Rights Reserved </div><div class="col text-right">Processed: <b>0.053</b>, SQL: <b>9</b></div></div></div></footer><script src="./lang/en-us/lang.js?2.2.0"></script><script src="view/js/jquery.min.js?2.2.0"></script><script src="view/js/popper.min.js?2.2.0"></script><script src="view/js/bootstrap.min.js?2.2.0"></script><script src="view/js/xiuno.js?2.2.0"></script><script src="view/js/bootstrap-plugin.js?2.2.0"></script><script src="view/js/async.min.js?2.2.0"></script><script src="view/js/form.js?2.2.0"></script><script> var debug = DEBUG = 0; var url_rewrite_on = 1; var url_path = './'; var forumarr = {"1":"Tech"}; var fid = 1; var uid = 0; var gid = 0; xn.options.water_image_url = 'view/img/water-small.png'; </script><script src="view/js/wellcms.js?2.2.0"></script><a class="scroll-to-top rounded" href="javascript:void(0);"><i class="icon-angle-up"></i></a><a class="scroll-to-bottom rounded" href="javascript:void(0);" style="display: inline;"><i class="icon-angle-down"></i></a></body></html><script> var forum_url = 'list-1.html'; var safe_token = 'gMnyZX0msqCmr0vWiv23D0pZD2j8st_2FJqBFlulGknZbTun87QBkvouMbfP7AuFI7iLsAOhr26vVRTCSYvQy_2FxA_3D_3D'; var body = $('body'); body.on('submit', '#form', function() { var jthis = $(this); var jsubmit = jthis.find('#submit'); jthis.reset(); jsubmit.button('loading'); var postdata = jthis.serializeObject(); $.xpost(jthis.attr('action'), postdata, function(code, message) { if(code == 0) { location.reload(); } else { $.alert(message); jsubmit.button('reset'); } }); return false; }); function resize_image() { var jmessagelist = $('div.message'); var first_width = jmessagelist.width(); jmessagelist.each(function() { var jdiv = $(this); var maxwidth = jdiv.attr('isfirst') ? first_width : jdiv.width(); var jmessage_width = Math.min(jdiv.width(), maxwidth); jdiv.find('img, embed, iframe, video').each(function() { var jimg = $(this); var img_width = this.org_width; var img_height = this.org_height; if(!img_width) { var img_width = jimg.attr('width'); var img_height = jimg.attr('height'); this.org_width = img_width; this.org_height = img_height; } if(img_width > jmessage_width) { if(this.tagName == 'IMG') { jimg.width(jmessage_width); jimg.css('height', 'auto'); jimg.css('cursor', 'pointer'); jimg.on('click', function() { }); } else { jimg.width(jmessage_width); var height = (img_height / img_width) * jimg.width(); jimg.height(height); } } }); }); } function resize_table() { $('div.message').each(function() { var jdiv = $(this); jdiv.find('table').addClass('table').wrap('<div class="table-responsive"></div>'); }); } $(function() { resize_image(); resize_table(); $(window).on('resize', resize_image); }); var jmessage = $('#message'); jmessage.on('focus', function() {if(jmessage.t) { clearTimeout(jmessage.t); jmessage.t = null; } jmessage.css('height', '6rem'); }); jmessage.on('blur', function() {jmessage.t = setTimeout(function() { jmessage.css('height', '2.5rem');}, 1000); }); $('#nav li[data-active="fid-1"]').addClass('active'); </script>