如何将参数从 Javascript 函数传递给 XSLT [英] How to pass parameter to XSLT from Javascript function
本文介绍了如何将参数从 Javascript 函数传递给 XSLT的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我浏览了许多试图解释如何实现这一目标的帖子,但没有一个能帮助我解决问题.
我有一个 HTML 文件,其中包含一个 XML 解析 JavaScript 函数,该函数进而呈现 XSLT 文件.问题是,我的 XML 文件中有多个记录",我只想要一个 XSLT 来呈现每条记录(而不是每条记录一个单独的 XSLT 文件).根据下面的代码,请有人建议我如何从包含记录 ID 的 JavaScript 传递参数(在我的 XML 文件中的每个 XML 记录中),以便单个"XSLT 可以使用源自的正确数据解析布局参数.
HTML
<html lang="zh-cn"><头><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/><meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1.0, user-scalable=no"/><title>天气应用</title><link href="../../css/materialize.css" type="text/css" rel="stylesheet" media="screen,projection"/><link href="../../css/animate.css" type="text/css" rel="stylesheet"/><link href="../../css/style.css" type="text/css" rel="stylesheet" media="screen,projection"/>头部><身体><div id="WeatherDetailsContainer"></div><!-- 脚本--><script src="https://code.jquery.com/jquery-2.1.1.min.js"></script><script src="../../js/materialize.js"></script><脚本>$(函数(){RenderXSLT();});函数加载XMLDoc(文件名){如果(window.ActiveXObject){xhttp = new ActiveXObject("Msxml2.XMLHTTP");} 别的 {xhttp = 新的 XMLHttpRequest();}xhttp.open("GET", 文件名, false);尝试 {xhttp.responseType = "msxml-document"} catch (err) {}//帮助 IE11xhttp.send("");返回 xhttp.responseXML;}函数 RenderXSLT() {xml = loadXMLDoc("datastore/Weather.xml");xslt = loadXMLDoc("transformations/WeatherDetailsCard.xslt");var currentLocation = localStorage.getItem('current_weather_location');if (window.ActiveXObject || xhttp.responseType == "msxml-document") {ex = xml.transformNode(xslt);document.getElementById("WeatherDetailsContainer").innerHTML = ex;}else if (document.implementation && document.implementation.createDocument) {xsltProcessor = new XSLTProcessor();xsltProcessor.importStylesheet(xslt);/** 我相信这是如何设置参数,但它没有用 **///xsltProcessor.setParameter(null, "cityname", currentLocation);resultDocument = xsltProcessor.transformToFragment(xml, document);document.getElementById("WeatherDetailsContainer").appendChild(resultDocument);}}