使用JavaScript獲取Django模板指定鍵值數(shù)據(jù)
Django中利用js來操作數(shù)據(jù)的常規(guī)操作一般為點(diǎn)(.)操作符來獲取字典或列表的數(shù)據(jù),一般如{{data.0}},{{data.arg}}
但有時(shí)如果數(shù)據(jù)是嵌套類型的數(shù)據(jù)時(shí),直接獲取某個(gè)值就變得困難了,比如下面的格式要獲取
correct中qxl的值
startArgsSet={'correct':{'qxl':0,'kkx':0},'reliable':{'qxl':0,'kkx':0},'security':{'qxl':0,'kkx':0},'understand':{'qxl':0,'kkx':0},'entropy':{'qxl':0,'kkx':0},'mature':{'qxl':0,'kkx':0},'active':{'qxl':0,'kkx':0},'service':{'qxl':0,'kkx':0},'file':{'qxl':0,'kkx':0},'tech':{'qxl':0,'kkx':0},'property':{'qxl':0,'kkx':0},'organize':{'qxl':0,'kkx':0},'develop':{'qxl':0,'kkx':0},'source':{'qxl':0,'kkx':0},'update':{'qxl':0,'kkx':0},'fix':{'qxl':0,'kkx':0},'quality':{'qxl':0,'kkx':0},'meanNum':{'qxl':0,'kkx':0},'variance':{'qxl':0,'kkx':0}}
這時(shí)候如果改變數(shù)據(jù)格式為列表中的無嵌套字典格式比較麻煩,可以自定義過濾器來獲取數(shù)據(jù),
from django.template.defaulttags import register@register.filterdef getArgQxlValue(dictionary,arg): return dictionary[arg][’qxl’] @register.filterdef getArgKkxValue(dictionary,arg): return dictionary[arg][’kkx’] @register.filterdef getArgName(dictionary,arg): return dictionary[arg][’name’]
在模板中就可以以這樣寫
<!-- the second important page of the project-->{% load staticfiles %}<!DOCTYPE html><html><head> <meta charset='utf-8'> <title>超標(biāo)信息</title> <script src='http://www.baoyu77737.com/bcjs/{% static ’js/a-mynewjs.js’ %}'></script></head><body> {{ guestSetArgs|safe }}<br><br><br> {{ warningdata|safe }}<br><br> <script> {% for i in guestSetArgs %} {% for j in warningdata %} if('{{i}}'=='{{j}}') { if(Number({{warningdata|getArgQxlValue:j}})>Number({{guestSetArgs|getArgQxlValue:i}})) var setArgStr='{{warningdata|getArgName:i}} 超出閥值 閥值:{{guestSetArgs|getArgQxlValue:j}} 檢測(cè)值:{{warningdata|getArgQxlValue:j}}<br>' document.write(setArgStr); } {% endfor %} {% endfor %} </script></body></html>
形如{{warningdata|getArgQxlValue:j}},就可以獲取到里面的值了
稍做美化
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法2. UDDI FAQs3. ASP基礎(chǔ)入門第三篇(ASP腳本基礎(chǔ))4. css進(jìn)階學(xué)習(xí) 選擇符5. jsp實(shí)現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫的方法6. asp.net core項(xiàng)目授權(quán)流程詳解7. ASP.NET Core實(shí)現(xiàn)中間件的幾種方式8. jsp網(wǎng)頁實(shí)現(xiàn)貪吃蛇小游戲9. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)10. JSP之表單提交get和post的區(qū)別詳解及實(shí)例
