获取不返回任何表单的表单-Django 2

时间:2019-02-20 15:21:58

标签: python django forms post get

我正在尝试根据输入表单过滤视图。这意味着我要存储输入变量并以此过滤视图的模型。

有两种方法可以执行此操作:通过POST或GET。我已经尝试过这两个方法,但是我相信GET方法会更有用。

我不知道问题是否出在forms.py或urls.py,views.py和html模板上没有使用表单。

无论如何。这是我的代码:

views.py

class PareceresHistAsset(LoginRequiredMixin, ListView):
    login_url = 'login/'
    redirect_field_name = 'redirect_to'
    template_name = "dash_asset.html"

    # Obtendo o ano anterior ao vigente
    ano = datetime.now().year - 1
    # Model Utilizado
    model = Pareceres
    queryset = Pareceres.objetos.filter(data_comite__year__gte=ano).filter(segmento='asset')

    # Criando os dados de context da view
    def get_context_data(self, **kwargs):
        ## Queryset do objeto
        queryset = self.queryset

        # Teste
        data_inicial = self.request.GET.get('data_inicial')
        print(data_inicial)
...

urls.py

from portal.views import *
from django.urls import path
from django.contrib.auth.views import LoginView

app_name = 'portal'

# urlpatterns contém a lista de roteamento URLs

urlpatterns = [
    # GET /
...
    path('asset/dash', PareceresHistAsset.as_view(), name='dash_asset'),
...
]

dash_asset.html

<div class="card mt-3">
    <div class="card-body">    
        <form method="get">
            <div class="row">
                <!-- Data Inicial-->
                <div class="col-2">
                    <label for="data_inicial">Data Inicial</label>
                    <input id="data_inicial" width="150" name="data_inicial"/>
                </div>
                <!-- Data Final -->
                <div class="col-2">
                    <label for="data_final">Data Final</label>
                    <input id="data_final" width="150" name="data_final"/>
                </div>
                <!-- Botão Submitt-->
                <div class="col-3 text-left">
                    <br>
                    <button class="btn btn-primary btn-sm" id="filtra_datas" type="submit">Atualizar</button>
                </div>
        </form>
        </div>
    </div>
</div>

以及输入表单中使用的javascript

    <!-- Material Design Date Picker -->
    <script src="https://unpkg.com/gijgo@1.9.11/js/gijgo.min.js" type="text/javascript"></script>
    <link href="https://unpkg.com/gijgo@1.9.11/css/gijgo.min.css" rel="stylesheet" type="text/css" />


    function formatDate(date) {
        var d = new Date(date),
            month = '' + (d.getMonth() + 1),
            day = '' + d.getDate(),
            year = d.getFullYear();

        if (month.length < 2) month = '0' + month;
        if (day.length < 2) day = '0' + day;

        return [day, month, year].join('/');
    }    

    $('#data_inicial').datepicker({ 
        format:

 'dd/mm/yyyy',
    value: '01/01/2019',
});
$('#data_final').datepicker({
    format: 'dd/mm/yyyy',
    value: formatDate(Date())
});

当我提交表单时,仅问号会添加到我的URL中。 是从http://127.0.0.1:8000/asset/dashhttp://127.0.0.1:8000/asset/dash吗?

另一件事是变量data_inicial(在get_context_data内部)不返回任何值。

有人知道如何解决吗?

我在这上面停留了三天。

谢谢。

编辑: 在输入中插入名称属性,并将名称和ID从data_incial更改为data_inicial。

仍然不返回

1 个答案:

答案 0 :(得分:1)

您尚未为输入提供name属性;否则,浏览器将不会发送任何数据。

<input id="data_inicial" name="data_inicial" width="150" />

(还请注意错别字; data_incialdata_inicial。)