django ListView的使用 ListView中獲取url中的參數(shù)值方式
view.py
from django.views.generic import ListView,DetailViewfrom xxxx.models import Model_Nameclass Colortag_view(ListView): #context_object_name = ’如果不指定的話在html頁(yè)面中 可以使用object_list獲取’ context_object_name = ’object_list’ #template_name=’html頁(yè)面所在目錄’ template_name=’caradmin/colortags/colortags.html’ #自定義查詢方法 def get_queryset(self): #獲取url 中的值 比如http://127.0.0.1/admin/colortags/?name_text=紅色 print(self.request.GET.dict()) return Model_Name.objects.filter(**self.request.GET.dict())
urls.py
from . import viewsurlpatterns = [ path(’colortags/’, views.Colortag_view.as_view(), name = ’modelname_list’),]
補(bǔ)充知識(shí):Django分類查詢和關(guān)鍵字查詢以及查詢后的分頁(yè)
思路:分類和關(guān)鍵字查詢分為以下幾種情況:
1、只按照分類查詢
2、值按照關(guān)鍵字查詢
3、分類和關(guān)鍵字一起查詢
第一種情況,值按照分類查詢:
我們寫了一個(gè)select下拉菜單來(lái)進(jìn)行選擇分類,當(dāng)我們選中某一個(gè)分類時(shí),則跳轉(zhuǎn)到相應(yīng)的分類的商品的展示頁(yè)面。
<!-- 點(diǎn)擊類別跳轉(zhuǎn)到則展示相應(yīng)的分類 --> $('#p_type').change(function(){ var type = $(this).val() location.href = ’/backweb/good_list/?type=’+type })
通過(guò)原生js通過(guò)onchange給select的option標(biāo)簽綁定事件,jQ中使用change對(duì)select進(jìn)行事件綁定,通過(guò)$(this)拿到當(dāng)前點(diǎn)擊的標(biāo)簽。
將獲取到分類值做為?后的參數(shù)傳入視圖中,在視圖中先將數(shù)據(jù)通過(guò)傳遞的分類進(jìn)行篩選,再將篩選后的數(shù)據(jù)傳遞到頁(yè)面進(jìn)行渲染。
如果我們此時(shí)還做了分頁(yè)展示,則將后端處理數(shù)據(jù)時(shí)的分類值也傳到頁(yè)面,在我們點(diǎn)擊分頁(yè)時(shí)跳轉(zhuǎn)的地址?后將分類值作為參數(shù)再次傳遞回后端進(jìn)行處理。
第二種情況,只按照關(guān)鍵字查詢:
和分類查詢類似,將文本輸入標(biāo)簽(例如text類型的input)綁定事件,獲取到輸入的值,將獲取的值作為地址?后的參入傳遞到后端。在后端通過(guò)地址后的參數(shù)將數(shù)據(jù)進(jìn)行模糊(constatins)篩選,再將篩選后的商品和參數(shù)傳遞回前端,將數(shù)據(jù)在前端進(jìn)行展示
當(dāng)我們點(diǎn)擊分頁(yè)時(shí),將查詢值作為參數(shù)傳遞回后端。
第三種情況,同時(shí)按照分類和關(guān)鍵字進(jìn)行查詢:
此時(shí)我們需要在地址?后傳遞兩個(gè)參數(shù),一個(gè)是分類一個(gè)是關(guān)鍵字,然后在后端接收參數(shù)并進(jìn)行篩選
<!-- 關(guān)鍵字查詢 -->function select_goods(){ var context=$(’#context’).val() var type = $(’.select’).val() if (context){ location.href = ’/backweb/good_list/?type=’+type+’&context=’+context }else{ location.href = ’/backweb/good_list/?type=’+type } }
分頁(yè)跳轉(zhuǎn)地址代碼
<a href='http://www.lshqa.cn/bcjs/{% url ’backweb:good_list’ %}?type={{ type_id }}&context={{ context }}&page=1' rel='external nofollow' >第一頁(yè)</a>
views代碼
def good_list(request): if request.method == ’GET’: page_num = int(request.GET.get(’page’, 1)) type = request.GET.get(’type’,0) context = request.GET.get(’context’,’’) # 如果拿不到分類則將type_id設(shè)置為0 if not type: type_id = int(type) else: type_id = int(type) # 所有的分類 type_list = FoodType.objects.all() # 根據(jù)相應(yīng)的分類查找相應(yīng)的商品 # 如果type_id不為0則獲取相應(yīng)分類的商品 if not type_id: goods = Goods.objects.all() else: goods = Goods.objects.filter(goods_type_id=type_id) # 如果有搜索條件則按照搜索條件模糊查詢 if context: goods = Goods.objects.filter(goods_type_id=type_id,productname__contains=context) if not goods: goods = Goods.objects.filter(goods_type_id=type_id,productname__contains=context[-1])
以上這篇django ListView的使用 ListView中獲取url中的參數(shù)值方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. docker compose idea CreateProcess error=2 系統(tǒng)找不到指定的文件的問(wèn)題2. 一文秒懂idea的git插件跟翻譯插件3. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法4. XML解析錯(cuò)誤:未組織好 的解決辦法5. XML入門的常見(jiàn)問(wèn)題(四)6. asp下利用xml打包網(wǎng)站文件7. jsp實(shí)現(xiàn)登錄驗(yàn)證的過(guò)濾器8. 爬取今日頭條Ajax請(qǐng)求9. JS中的常見(jiàn)數(shù)組遍歷案例詳解(forEach, map, filter, sort, reduce, every)10. XML入門的常見(jiàn)問(wèn)題(一)
