javascript - 将js变量传递给django View

标签 javascript jquery django forms

<分区>

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

<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>

最佳答案

我可以在 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.e. 在您的后续 View 中轻松访问传递的数组/变量。 {{ scores }} 在你的 Django 模板中

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

关于javascript - 将js变量传递给django View ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7604471/

相关文章:

python - 鹡鸰 block : accessing context and request in overridden get_context

javascript - 如何一一获取多行并检查它们的值?

javascript - 如何在 Web 应用程序中创建图表?

javascript - 如果 CDN 失败,如何使用 javascript 回退到本地服务器以获取 fontawesome?

javascript - 如何覆盖 print css 中的内联样式?

django - 如何正确安装 django-nose?

django - reddit 风格的 Django 投票

javascript - 将 iframe 的内容设置为 polymer 元素

javascript - 当搜索下拉列表时,是否可以将结果带到顶部?

jquery - 如何使工具提示(qtip2)位于顶部中心?以及如何在其中添加图像?