Фильтр XML из параметров поиска - PullRequest
0 голосов
/ 14 июля 2010

Я создаю небольшую функцию поиска на создаваемом сайте. Я работаю с Umbraco CMS, и все узлы, которые мне нужно искать, являются дочерними элементами страницы, на которой ведется поиск. Прямо сейчас у меня есть окно поиска с семью полями. три поля ввода и четыре раскрывающихся списка.

Это XML, из которого мне нужно найти свои результаты:

<Modellist id="1073" parentID="1052" level="2" writerID="0" creatorID="0" nodeType="1065" template="1066" sortOrder="0" createDate="2010-07-12T20:23:35" updateDate="2010-07-12T21:25:13" nodeName="Piger-girls" urlName="piger-girls" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073" isDoc="">
<title>Girls</title>
<metaDescription></metaDescription>
<metaTitle />
<metaKeywords />
<nameInMenu />
<Model id="1075" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="1" createDate="2010-07-12T20:25:31" updateDate="2010-07-12T21:01:58" nodeName="Lene Madsen" urlName="lene-madsen" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1075" isDoc="">
    <title>Lene M</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>014</modelnummer>
    <height>120</height>
    <size>122</size>
    <eyeColor>Blå</eyeColor>
    <hairColor>Blond</hairColor>
    <shoeSize>26-30</shoeSize>
</Model>
<Model id="1077" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="2" createDate="2010-07-13T19:04:42" updateDate="2010-07-13T19:05:23" nodeName="Julie B" urlName="julie-b" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1077" isDoc="">
    <title>Julie B</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>002</modelnummer>
    <height>129</height>
    <size>104</size>
    <eyeColor>Grøn</eyeColor>
    <hairColor>Sort</hairColor>
    <shoeSize>26-30</shoeSize>
</Model>
<Model id="1078" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="3" createDate="2010-07-13T19:05:38" updateDate="2010-07-13T19:06:06" nodeName="Marlene U" urlName="marlene-u" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1078" isDoc="">
    <title>Marlene U</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>007</modelnummer>
    <height>89</height>
    <size>86</size>
    <eyeColor>Grå</eyeColor>
    <hairColor>Blond</hairColor>
    <shoeSize>26-30</shoeSize>
</Model>
<Model id="1079" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="4" createDate="2010-07-13T19:06:18" updateDate="2010-07-13T19:07:20" nodeName="Louise N" urlName="louise-n" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1079" isDoc="">
    <title>Louise N</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>022</modelnummer>
    <height>148</height>
    <size>152</size>
    <eyeColor>Brun</eyeColor>
    <hairColor>Brun</hairColor>
    <shoeSize>31-35</shoeSize>
</Model>
<Model id="1080" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="5" createDate="2010-07-13T19:07:35" updateDate="2010-07-13T19:07:59" nodeName="Marie A" urlName="marie-a" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1080" isDoc="">
    <title>Marie A</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>010</modelnummer>
    <height>146</height>
    <size>128</size>
    <eyeColor>Blå</eyeColor>
    <hairColor>Rød</hairColor>
    <shoeSize>36-40</shoeSize>
</Model>
<Model id="1081" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="6" createDate="2010-07-13T19:08:22" updateDate="2010-07-13T19:08:53" nodeName="Sandra F" urlName="sandra-f" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1081" isDoc="">
    <title>Sandra F</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>013</modelnummer>
    <height>126</height>
    <size>122</size>
    <eyeColor>Blå</eyeColor>
    <hairColor>Brun</hairColor>
    <shoeSize>31-35</shoeSize>
</Model>
<Model id="1082" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="7" createDate="2010-07-13T19:09:10" updateDate="2010-07-13T19:09:51" nodeName="Laura N" urlName="laura-n" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1082" isDoc="">
    <title>Laura N</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>004</modelnummer>
    <height>73</height>
    <size>74</size>
    <eyeColor>Grøn</eyeColor>
    <hairColor>Rød</hairColor>
    <shoeSize>18-20</shoeSize>
</Model>
<Model id="1083" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="8" createDate="2010-07-13T19:10:09" updateDate="2010-07-13T19:11:19" nodeName="Gitte R" urlName="gitte-r" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1083" isDoc="">
    <title>Gitte R</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>017</modelnummer>
    <height>105</height>
    <size>110</size>
    <eyeColor>Grøn</eyeColor>
    <hairColor>Brun</hairColor>
    <shoeSize>21-25</shoeSize>
</Model>
<Model id="1084" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="9" createDate="2010-07-13T19:11:30" updateDate="2010-07-13T19:12:56" nodeName="Mia H" urlName="mia-h" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1084" isDoc="">
    <title>Mia H</title>
    <images></images>
    <polaroid />
    <videoSmall />
    <videoLarge />
    <modelnummer>015</modelnummer>
    <height>138</height>
    <size>140</size>
    <eyeColor>Blå</eyeColor>
    <hairColor>Rød</hairColor>
    <shoeSize>31-35</shoeSize>
</Model>

Теги "size", "eyeColor", "hairColor" и "shoeSize" должны соответствовать четырем раскрывающимся спискам в моем окне поиска. Тег с названием «title» можно искать из поля ввода с именем name. И тогда у меня есть еще один текстовые поля, называемые "heightFrom" и "heightTo". здесь пользователь может искать по высоте, и это должно быть сопоставлено с XML-тэгом, называемым «высотой».

Мне легко сказать, что если поле имени не пустое, я могу просто сделать это:

<xsl:apply-templates select="$currentPage/*[@isDoc][contains(Exslt.ExsltStrings:lowercase(./title),$name)]">
                <xsl:sort data-type="text" select="title" order="ascending"/>
            </xsl:apply-templates>

$ name содержит искомое имя. И это даст мне все узлы, которые имеют искомое имя в теге title. Но как я могу получить от этого. Конечно, я могу создать выбор с большим (более 40) моментом, когда это произойдет, но это будет большой работой, и ее будет сложно поддерживать в будущем. Одна из трудностей заключается в том, что ни одно из полей не является обязательным, поэтому я не знаю, какие поля будут заполнены. Могу ли я сделать что-нибудь еще?

Кстати, URL в примере может выглядеть так: http://my.site/search.aspx?hf=150&ht=&size=62&ec=&hc=&ss=&name=Julie

У меня есть все значения в семи переменных, например:

<xsl:variable name="heightFrom" select="umbraco.library:Request('hf')"/>
<xsl:variable name="heightTo" select="umbraco.library:Request('ht')"/>
<xsl:variable name="size" select="umbraco.library:Request('size')"/>
<xsl:variable name="eyeColor" select="umbraco.library:Request('ec')"/>
<xsl:variable name="shoeSize" select="umbraco.library:Request('ss')"/>
<xsl:variable name="hairColor" select="umbraco.library:Request('hc')"/>
<xsl:variable name="name" select="Exslt.ExsltStrings:lowercase(umbraco.library:Request('name'))"/>

Любая помощь и материалы будут значительно оценены!

Заранее спасибо:)

/ Kim

1 Ответ

1 голос
/ 14 июля 2010

Я думаю, что вам нужно только выражение XPath в правильном контексте.Этот стайлшет:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:param name="heightFrom" select="120"/>
    <xsl:param name="heightTo" select="130"/>
    <xsl:param name="size" />
    <xsl:param name="eyeColor" />
    <xsl:param name="shoeSize" />
    <xsl:param name="hairColor" />
    <xsl:param name="name" />
    <xsl:template match="/">
        <Modellist>
            <xsl:copy-of select="*/Model[height >= $heightFrom and $heightTo >= height
                              or
                             height >= $heightFrom and not($heightTo)
                              or
                             not($heightFrom) and $heightTo >= height]
                            [size = $size or not($size)]
                            [eyeColor = $eyeColor or not($eyeColor)]
                            [$shoeSize >= substring-before(shoeSize,'-')
                              and 
                             substring-after(shoeSize,'-') >= $shoeSize
                              or
                             not($shoeSize)]
                            [hairColor = $hairColor or not($hairColor)]
                            [title = $name or not($name)]"/>
        </Modellist>
    </xsl:template>
</xsl:stylesheet>

Результат:

<Modellist>
    <Model id="1075" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="1" createDate="2010-07-12T20:25:31" updateDate="2010-07-12T21:01:58" nodeName="Lene Madsen" urlName="lene-madsen" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1075" isDoc="">
        <title>Lene M</title>
        <images></images>
        <polaroid />
        <videoSmall />
        <videoLarge />
        <modelnummer>014</modelnummer>
        <height>120</height>
        <size>122</size>
        <eyeColor>Blå</eyeColor>
        <hairColor>Blond</hairColor>
        <shoeSize>26-30</shoeSize>
    </Model>
    <Model id="1077" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="2" createDate="2010-07-13T19:04:42" updateDate="2010-07-13T19:05:23" nodeName="Julie B" urlName="julie-b" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1077" isDoc="">
        <title>Julie B</title>
        <images></images>
        <polaroid />
        <videoSmall />
        <videoLarge />
        <modelnummer>002</modelnummer>
        <height>129</height>
        <size>104</size>
        <eyeColor>Grøn</eyeColor>
        <hairColor>Sort</hairColor>
        <shoeSize>26-30</shoeSize>
    </Model>
    <Model id="1081" parentID="1073" level="3" writerID="0" creatorID="0" nodeType="1067" template="1068" sortOrder="6" createDate="2010-07-13T19:08:22" updateDate="2010-07-13T19:08:53" nodeName="Sandra F" urlName="sandra-f" writerName="Administrator" creatorName="Administrator" path="-1,1052,1073,1081" isDoc="">
        <title>Sandra F</title>
        <images></images>
        <polaroid />
        <videoSmall />
        <videoLarge />
        <modelnummer>013</modelnummer>
        <height>126</height>
        <size>122</size>
        <eyeColor>Blå</eyeColor>
        <hairColor>Brun</hairColor>
        <shoeSize>31-35</shoeSize>
    </Model>
</Modellist>
...