【问题标题】:iterating over loop in html and javascript only executing once - should be doing each time in the loop在 html 和 javascript 中迭代循环只执行一次 - 每次都应该在循环中执行
【发布时间】:2013-04-24 00:46:09
【问题描述】:

我正在尝试呈现一个显示评论数量(1 条评论或 xxx 条评论)的模板。我正在通过 jinja2 迭代 GAE 中的实体实例对象,但它只在第一个循环中执行脚本,之后的每个循环。我的代码有什么问题?

   <table>
    {% for each in courses_taught %}
 <tr>   
    <td id="num_reviews">           
             <script type='text/javascript'>   
        var html_output = "";               
            var review_count ={{each.num_reviews}};

                if (review_count ==1) {             
        html_output += "<a href='../course/{{each.key()}}'>1 review</a>";
        }               

        else if (review_count > 1) {
        html_output += "<a href='../detail/course/{{each.key()}}'>" + num_reviews + " reviews</a>";
        }

        else {
        html_output +="<a id='trailblazer' href='../../../review/writeReview/{{each.key()}}'>Be the trailblazer</a>";
        }

              var reviewCount = document.getElementById("num_reviews");  
      reviewCount.innerHTML = html_output;              

</script>   
</td>

 </tr>

{% endfor %}

【问题讨论】:

  • 为什么不使用 jinja 本身而不使用任何 javascript?不需要。
  • 无论如何,您必须为您的td 提供每一行的唯一ID,例如:&lt;td id="num_reviews-{{each.unique_id}}"&gt;。在你的 javascript 中:var reviewCount = document.getElementById("num_reviews-{{each.unique_id}}");.

标签: javascript google-app-engine jinja2


【解决方案1】:

无需任何额外 javascript 的 Jinja 解决方案:

{% for each in courses_taught %}
    {{ each.num_reviews }}
    review{% if each.num_reviews > 1 %}s{% endif %}
{% endfor %}

如果你想使用 javascript(为什么?):

{% for each in courses_taught %}
    <tr>   
        <td id="num_reviews-{{each.unique_id}}">           
            <script type='text/javascript'>   
                var html_output = "";               
                var review_count = {{each.num_reviews}};

                if (review_count == 1) {             
                    html_output += "<a href='../course/{{each.key()}}'>1 review</a>";
                }               

                else if (review_count > 1) {
                   html_output += "<a href='../detail/course/{{each.key()}}'>" + num_reviews + " reviews</a>";
                }

                else {
                    html_output +="<a id='trailblazer' href='../../../review/writeReview/{{each.key()}}'>Be the trailblazer</a>";
                }

                var reviewCount = document.getElementById("num_reviews-{{each.unique_id}");  
                reviewCount.innerHTML = html_output;
            </script>
        </td>

    </tr>
{% endfor %}

其中unique_id 是循环中每个each 元素的唯一属性。

【讨论】:

  • ohhh - 不知道你可以在 jinja 中做到这一点!