如何使用django的javascript变量,反之亦然?

时间:2017-04-11 10:50:28

标签: javascript python html django web

当用户点击按钮时,我尝试使用JavaScript生成1到132(含)之间的随机数。

到目前为止,它产生了价值,我能够获得所需的输出。

问题: 我是在自定义Django过滤器(或其他任何调用)中使用生成的值。让我用我的代码更好地解释一下:

<script type="text/javascript">
    function random_generator()
    {
      var rand = [];
      var i;
      var j;
      var text = "";
      for(i = 0; i < 5; ++i)
      {
        rand[i] = Math.floor((Math.random() * 132) + 1);
        text += rand[i];
      }
      document.getElementById('rand1').innerHTML = text; //Just trying to see if the numbers are generated properly

      var text2 = "{%for i in allb %}{%if i.id == " + text + "|add:0 %}<p>{{ i.name }}</p>{% endif %}{%endfor%}";
      document.getElementById('rand2').innerHTML = text2;
      document.writeln(rand[0]);
    }
  </script>

这是我尝试做的其他事情:

<div id="b005" class="modal">
    <div id="rand1"></div>
    <div id="rand2"></div>
      {%for i in allb %}
        {%if i.id == **WANT TO USE THE JS VARIABLE HERE**|add:0 %}
          <p>{{ i.name }}</p>
        {% endif %}
      {%endfor%}
  </div>

注意: allb是我从views.py传递的对象

还有其他方法可以做同样的事吗?

提前谢谢你:)

1 个答案:

答案 0 :(得分:0)

丹尼尔已经提到过,你必须先了解幕后发生的事情。您的django模板仅存在于您的服务器上,并且所有模板代码都在该服务器上执行。此模板代码也可用于非html呈现,就像在random_generator()脚本中一样。

但是浏览器只接收评估版的模板。因此,无法将您的django模板代码(服务器端)与客户端js进行比较。