使用JavaScript獲取Django模板指定鍵值數(shù)據(jù)
Django中利用js來操作數(shù)據(jù)的常規(guī)操作一般為點(.)操作符來獲取字典或列表的數(shù)據(jù),一般如{{data.0}},{{data.arg}}
但有時如果數(shù)據(jù)是嵌套類型的數(shù)據(jù)時,直接獲取某個值就變得困難了,比如下面的格式要獲取
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ù)據(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://m.4tl426be.cn/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}} 檢測值:{{warningdata|getArgQxlValue:j}}<br>' document.write(setArgStr); } {% endfor %} {% endfor %} </script></body></html>
形如{{warningdata|getArgQxlValue:j}},就可以獲取到里面的值了
稍做美化
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. HTML DOM setInterval和clearInterval方法案例詳解2. 告別AJAX實現(xiàn)無刷新提交表單3. CSS hack用法案例詳解4. Vue+elementUI下拉框自定義顏色選擇器方式5. 使用純HTML的通用數(shù)據(jù)管理和服務(wù)6. 低版本IE正常運行HTML5+CSS3網(wǎng)站的3種解決方案7. 使用css實現(xiàn)全兼容tooltip提示框8. css代碼優(yōu)化的12個技巧9. css進階學(xué)習(xí) 選擇符10. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)
