Я хочу оптимизировать свой JavaScript, но я столкнулся с небольшим количеством проблем. Я использую XSLT-преобразование, и основная идея состоит в том, чтобы получить часть XML и выполнить ее подзапрос, чтобы вызовы были быстрее и дешевле. Это часть XML:
<suite>
<table id="spis" runat="client">
<rows>
<row id="spis_1">
<dispatch>'2008', '288627'</dispatch>
<data col="urGod">
<title>2008</title>
<description>Ur. god.</description>
</data>
<data col="rbr">
<title>288627</title>
<description>Rbr.</description>
</data>
...
</rows>
</table>
</suite>
На странице это javascript, который работает с этим:
// this is my global variable for getting the elements so I just get the most
// I can in one call
elemCollection = iDom3.Table.all["spis"].XML.DOM.selectNodes("/suite/table/rows/row").context;
//then I have the method that uses this by getting the subresults from elemCollection
//rest of the method isn't interesting, only the selectNodes call
_buildResults = function (){
var _RowList = elemCollection.selectNodes("/data[@col = 'urGod']/title");
var tmpResult = [''];
var substringResult="";
for (i=0; i<_RowList.length; i++) {
tmpResult.push(_RowList[i].text,iDom3.Global.Delimiter);
}
...
//this variant works
elemCollection = iDom3.Table.all["spis"].XML.DOM
_buildResults = function (){
var _RowList = elemCollection.selectNodes("/suite/table/rows/row/data[@col = 'urGod']/title");
var tmpResult = [''];
var substringResult="";
for (i=0; i<_RowList.length; i++) {
tmpResult.push(_RowList[i].text,iDom3.Global.Delimiter);
}
...
Проблема в том, что я не могу найти способ использовать подрезультаты, чтобы получить то, что мне нужно.