将js变量传递给django视图

时间:2011-09-29 23:26:40

标签: javascript jquery django forms

我正在使用jquery .submit()函数来计算两个变量(f_amount和f_variables),但我不知道如何将它们传递给下一个django视图。

<form method="POST" action="/app/view">{% csrf_token %}                    
                    <select  id="fd" name="fd">
                        <option value="2">2</option>
                        <option value="3">3</option>
                        <option value="5">5</option>
                        <option value="1">1</option>
                    </select>

                <div id="demo2" class="demo">
                <ul>
                {% for f_type, fs in f.items %}
                    <li>
                        <a>{{ f_type }}</a>
                        <ul>
                            {% for f in fs %}
                                <li><a id="{{f.0}}">{{f.1}}</a></li>
                            {% endfor %}
                        </ul>
                    </li>
                {% endfor %}
                </ul>
                </div>
                <input id="plan" type="submit" value="sched it!" class="btn primary" />
        </form>

<script>
$("form").submit(function() {
                var checked_ids = new Array();
                var f_amount = $("select option:selected").val();
                $("#demo2").jstree("get_checked",null,true).each 
                    (function (index,value) {
                        if (value.children[2].id) { 
                            checked_ids.push(value.children[2].id); 
                        }
                    });
                var f_ids = checked_ids.join(" ");

 });
</script>

2 个答案:

答案 0 :(得分:1)

我可以在Django 2.1中这样做

x123.html 首先在第一个html文件中创建一个隐藏的输入字段

<form id="scoresForm" method="POST">
  {% csrf_token %}
  <input type="hidden" name="scores" value=""/>
</form>

views.py ,然后在views.py中定义您的View并进行POST数据处理

def result(request, league_id, season_id, matchday):
    scores = request.POST.get("scores", None)
    if scores != None:
        scores = scores.replace("&quot;", "'")
    #scores = scores[1:-1]
    scores = json.loads(scores)
    context = {
        'league_id': league_id,
        'season_id': season_id,
        'matchday': matchday,
        'scores': scores,
    }
    return render(request, 'matchstatistics/result.html', context)

x123.js ,最后在属于您的第一个html模板的JS文件中

    var resultUrl = currentUrl + "/result/" + league_id + "/" + season_id + "/" + matchday + "/";
    var scoresForm = document.forms['scoresForm'];
    scoresForm.action = resultUrl;
    scoresForm.elements["scores"].value = JSON.stringify(scores);
    document.getElementById("scoresForm").submit();

y123.html ,您可以通过调用f在下面的视图中轻松访问传递的数组/变量。在您的Django模板中{{scores}}

请随时优化代码,尤其是Django / Python / JavaScript新增的JSON-Object序列化和反序列化部分:)

答案 1 :(得分:0)

How do you pass or share variables between django views?

您可以通过REST发送信息,查看以查看...这些变量源自javascript是无关紧要的。

还有其他方法,但这个方式似乎最适合你正在做的事情。