0

ネストされたデータがある場合、Backbone.js でテンプレートを作成する方法を教えてください。

データ例:

var questions = [
    {
        id: 0,
    question: [
        {
            id: 101,
            text: 'What is your name?',
        },
        {
            id: 102,
            text: 'What is your lastname?',
        },
        {
            id: 103,
            text: 'What is yout sex?',
        },
        {
            id: 104,
            text: 'How old are you?',
        },
    ]
}
];

出力用のhtmlコード:

<div id="qu_0" class="questions"><div>
    <p><input type="radio" rel="question" name="question_0" id="i101" value="101" /><label for="i101">What is your name?</label></p>
    <p><input type="radio" rel="question" name="question_0" id="i102" value="102" /><label for="i102">What is your firstname?</label></p>
    <p><input type="radio" rel="question" name="question_0" id="i103" value="103" /><label for="i103">What is your sex?</label></p>
    <p><input type="radio" rel="question" name="question_0" id="i104" value="104" /><label for="i104">How old are you?</label></p>
    <button type="button" name="next"><b>Answer</b></button>
</div></div>

次のようなものを取得する必要があることを理解しています。

<script id="questionTemplate" type="text/template">
<div>
    <p><input type="radio" rel="question" name="question_<%= id %>" id="i<%= q.id %>" value="<%= q.id %>" /><label for="i<%= q.id %>"><%= q.text %></label></p>
    <button type="button" name="next"><b>Answer</b></button>
</div>
</script>

しかし、ネストされた質問の配列をテンプレートに表示する方法がわかりません。お願い助けて。

4

1 に答える 1

1

次のように配列をループできます。

<script id="questionTemplate" type="text/template">
    <% for(var question in questions) { %>
        <div id="qu_<%= question.id %>" class="questions"><div>
        <% for(var q in questions,question) { %>
            <p><input type="radio" rel="question" name="question_<%= q.id %>" id="i<%= q.id %>" value="<%= q.id %>" /><label for="i<%= q.id %>"><%= q.text %></label></p>
        <% } %>
        </div></div>
    <% } %>
    <button type="button" name="next"><b>Answer</b></button>
</script>
于 2013-09-27T19:07:18.337 に答える