Django自關(guān)聯(lián)實現(xiàn)多級聯(lián)動查詢實例
1 問題引出
我們在開發(fā)網(wǎng)站的時候可能會遇到這種情況,多個字段之間有一定的關(guān)聯(lián)性,比如省市縣,選擇省,之后下一個選擇框的值則為該省的市集合,選擇市之后下一個選擇框的值為該市的縣集合。
一種實現(xiàn)方式是,建立三個模型表,用外鍵一對多方式,顯然這樣是不太合理的。Django提供了自關(guān)聯(lián)的實現(xiàn),模型自身關(guān)聯(lián),即一條數(shù)據(jù)關(guān)聯(lián)另一條數(shù)據(jù)。
本文以省市縣為案例介紹其具體實現(xiàn)方法。
2 具體實現(xiàn)
2.1 建立數(shù)據(jù)表Model
在model.py中建立數(shù)據(jù)表
class AdressInfo(models.Model): address = models.CharField(max_length = 200, null = True, blank = True, verbose_name = ‘地址’) pid = models.ForeignKey(‘self’ , null = True, blank = True, verbose_name = ‘自關(guān)聯(lián)’) def __str__(self): return self.adress
說明:
name :省市縣的名字pid:外鍵,self自關(guān)聯(lián),這里也可以使用 AdressInfonull:為True表示可以為空,因為省級行政單位沒有父級blank:為True表示admin后臺數(shù)據(jù)寫入的時候可以允許為空
然后遷移數(shù)據(jù)庫
python manage.py makemigrationspython manage.py migrate
這時可以在后臺數(shù)據(jù)表中添加數(shù)據(jù)
2.2 后端url和view函數(shù)
將前端網(wǎng)頁地址映射為對應(yīng)函數(shù),用正則表達(dá)式獲取前端傳輸?shù)膒id
url.py 文件
urlpatterns = [ url(r’^addr/(d+)$’, Address.addrAPI, name = ’Addr)]
view.py 文件
def addrAPI(request,addr_id): # 接收一個參數(shù)的id,指model中的pid屬性對應(yīng)的字段 if (int(addr_id) == 0): # 為0表示查詢省,省的pid_id為null address_data = AddressInfo.objects.filter(pid__isnull = True).values(’id’,’address’) else: # 查詢市或其他縣 address_data = AddressInfo.objects.filter(pid_id = int(addr_id)).values(’id’,’address’) area_list = [] for a in address_data: area_list.append({’id’:a[’id’], ’address’:a[’address’]}) return JsonResponse(area_list, safe = False)
2.3 前端template
前端主要是顯示和執(zhí)行操作相應(yīng),具體實現(xiàn)是通過下拉框值的改變觸動相應(yīng)函數(shù)。這里只寫關(guān)鍵的地方。
address.html 文件
<body> <select id = ’pro’> <option value=’’>請選擇省</option> </select> <select id = ’city’> <option value=’’>請選擇市</option> </select> <select id = ’dis’> <option value=’’>請選擇縣</option> </select></body><script>address = function(a, b){ $.get(’/addr/’+a, function (dic){ $.each(dic, function(index, item){ b.append(’<option value='’ + item.id + ’'>’ + item.address + ’</option>’) }) })}$(function (){ // 獲取省市縣元素 pro = $(’#pro’) city = $(’#city’) dis = $(’#dis’) // 查詢省信息 address(0, pro) // 根據(jù)省查詢市信息 pro.change(function(){ city.empty().append(’<option value=''>請選擇市</option>’); dis.empty().append(’<option value=''>請選擇縣</option>’); adress(this.value, city) }) // 根據(jù)市查詢縣信息 city.change(function(){ dis.empty().append(’<option value=''>請選擇縣</option>’); adress(this.value, dis) })})</script>
3 效果
以上這篇Django自關(guān)聯(lián)實現(xiàn)多級聯(lián)動查詢實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向2. python matplotlib:plt.scatter() 大小和顏色參數(shù)詳解3. vue使用webSocket更新實時天氣的方法4. 淺談python出錯時traceback的解讀5. Python importlib動態(tài)導(dǎo)入模塊實現(xiàn)代碼6. android studio 打包自動生成版本號與日期,apk輸入路徑詳解7. 利用promise及參數(shù)解構(gòu)封裝ajax請求的方法8. 在Android中使用WebSocket實現(xiàn)消息通信的方法詳解9. Nginx+php配置文件及原理解析10. JSP數(shù)據(jù)交互實現(xiàn)過程解析
