簡體   English   中英

Django的多個提交按鈕

[英]django multiple submit buttons

我的Django模板中有很多按鈕。 每個按鈕都有不同的名稱{{transaction.id}}。 如何在視圖中引用(提交)單個按鈕?

base.html

<h3>Open transactions</h3>
    {% for transaction in transactions_open %}
    {{ transaction.id }} {{transaction.timestamp}} {{ transaction.currency }} {{ transaction.sell_or_buy }} {{ transaction.bid }} {{ transaction.date_add }}
    <form action="" method="POST">
    {% csrf_token %}
    <button type="submit" name={{ transaction.id }} value="close">Close</button>
    </form>
    </p>
    {% endfor %}

views.py

class MainView(View):

def get(self, request):

    transactions_open = DealModel.objects.filter(open_or_closed='OPEN')
    transactions_closed = DealModel.objects.filter(open_or_closed='CLOSED')
    content_dict = {'transactions_open': transactions_open,
                    'transactions_closed': transactions_closed}
    return TemplateResponse(request, 'base.html', content_dict)

def post(self,request):

    if request.method == 'POST':
        transactions_open = DealModel.objects.filter(open_or_closed='OPEN')
        transactions_closed = DealModel.objects.filter(open_or_closed='CLOSED')

        if request.POST.get('name???') == 'close':
        content_dict['answer'] = "Closed!!!"
        return TemplateResponse(request, 'base.html', content_dict)

這是我的例子

第一

def post(self,request):它將被稱為在請求方法是POST ,所以你不需要檢查它


第二

這個解決方案取決於我從問題中得到了什么
您不需要表單具有關閉按鈕。如果要隱藏它,可以使用javascript處理

<ul>{% for transaction in transactions_open %}
<li class="close_button" data-pk="{{ transaction.id }}">{{ transaction.id }} {{transaction.timestamp}} {{ transaction.currency }} {{ transaction.sell_or_buy }} {{ transaction.bid }} {{ transaction.date_add }}

<a type="submit"  value="close">Close</a>

</li>
{% endfor %}</ul>

使用jQuery的JavaScript文件

$('.close_button a').onclick(function(){
     $(this).parent(".close_button").hide(); // something like that
$.ajax{
            url: "{% url 'app_label:view_name' %}",
            data: {'data':$(this).data("pk")},
            method: "POST",
            success: function (result,status,xhr) {

                alert('closed Successfully.');

            },

})

在視圖中處理關閉交易:

class MyView(View):
    def post(self, request, *args, **kwargs):
        if request.is_ajax():
             id = request.post.get("pk")
             Transaction.objects.get(id=id).close() #develop close method at your model classes 

謝謝您的回答。 這是我對問題的解決方案:

class MainView(View):

    def post(self,request):

    if 'close' in request.POST.values():
        for key, value in request.POST.items():
            if value == 'close':
                deal_id = key # deal_id is the value of {{transaction.id}} in template file.

    if request.POST.get(deal_id) == 'close':
        closing_deal = DealModel.objects.get(id=deal_id)
        closing_deal.open_or_closed = 'Closed'
        closing_deal.save()
        content_dict['answer'] = "Closed!!!"
        return TemplateResponse(request, 'base.html', content_dict)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM