jQuery XML解析/探索
-
06-07-2019 - |
質問
次のXMLがあります-
<rows>
<row id="5">
<cell>Item1</cell>
<attrs>
<attr>
<id>1</id>
<type>CheckBox</type>
<values>
<value>
<id>10</id>
</value>
<value>
<id>11</id>
</value>
</values>
</attr>
<attr>
<id>2</id>
<type>CheckBox</type>
<values>
<value>
<id>20</id>
</value>
<value>
<id>21</id>
</value>
</values>
</attr>
</attrs>
</row>
</rows>
私がしたいのは、特定の行のそれぞれをループすることです。
すべての属性IDを取得するためにこれを実行しようとしましたが、値IDも取得しました。
function fillForm(id){
var theRow = $(theXmlDoc).find('row[id='+id+']').get()
$(theRow).find("attr").each(function(i)
{
alert($(this).find("id").text());
});
}
また、主な目標は各attrをループし、その後、attrのIDを持っている間に各値をループすることです。
PS他のライブラリを使ってそうするより簡単で簡単な方法を考えているなら、私は提案を募集しています。
事前に感謝、
解決
ループしようとしているものが明確ではありません。質問のタグの1つが文字化けしていたと思います。 「私がやりたいことは、特定の行のそれぞれをループすることです」と言います。そこにタグがあったと思います。
とにかく、jQueryを使用して解析済みのxmlドキュメントからデータを抽出する例をいくつか示します。コメントには、アラートの対象が示されます。
問題の一部は、属性の子ではなく兄弟としてid値を持っていることだと思います。より一貫性のある構造は次のように思われます:
<rows>
<row id="5">
<cell>Item1</cell>
<attrs>
<attr id="1">
<type>CheckBox</type>
<values>
<value>
<id>10</id>
</value>
<value>
<id>11</id>
</value>
</values>
</attr>
<attr id="2">
<type>CheckBox</type>
<values>
<value>
<id>20</id>
</value>
<value>
<id>21</id>
</value>
</values>
</attr>
</attrs>
</row>
</rows>
ただし、xmlを制御できない場合は、その提案を無視してください。 :-)
さて、ここにさまざまなデータを取得するための走査のサンプルがあります:
最初に&quot; Item1&quot;を取得しましょう
<script type="text/javascript">
// Item1
$.get('sample.xml', null, function (data, textStatus) {
alert( $(data).find('rows row[id=5] cell').text());
}, 'xml');
</script>
今、1と2を取得します
<script type="text/javascript">
// 1
// 2
$.get('sample.xml', null, function (data, textStatus) {
$(data).find('rows row[id=5] attrs attr > id').each( function(){
alert($(this).text()); // 1, 2
});
}, 'xml');
</script>
そして最後に、メインの属性IDを引き出して、それらを値に結び付けましょう:
<script type="text/javascript">
// rows row[id=5] attrs attr > id 1 has inner ids of 10,11
// rows row[id=5] attrs attr > id 2 has inner ids of 20,21
$.get('sample.xml', null, function (data, textStatus) {
var out = ''
$(data).find('rows row[id=5] attrs attr > id').each( function(){
out += 'rows row[id=5] attrs attr > id ' + $(this).text();
var innerIds = [];
$(this).siblings('values').find('value id').each(function(){
innerIds.push($(this).text())
});
out += ' has inner Ids of ' + innerIds.join(',') + '\n';
});
alert(out);
}, 'xml');
</script>
他のヒント
これはあなたのために働くはずです
function fillForm(id){
var row = $(theXmlDoc).find('row#+'+ id);
var ids = row.find( "attr > id");
ids.each(function(i)
{
alert($(this).text());
});
}
PS。 xpath のいずれかを使用できます。
var ids = document.evaluate( '//rows/row[@id='+id + ']/attr/id/text( )', theXmlDoc, null, XPathResult.ANY_TYPE, null );
所属していません StackOverflow