电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Django 后臺帶有字典的列表數據與頁面js交互實例

瀏覽:117日期:2024-05-28 13:25:38

1、這里只是簡單介紹一下Django的view如何跟js進行交互,首先,進入用戶明細的時候會進入一個頁面,叫用戶信息表,里面包含了用戶學習的課程和所得到的分數,每門課程對應一個分數,其中課程用下拉框依次顯示,選擇課程時動態顯示課程的分數,django view部分代碼如下:

def user_info(request, userid): if request.method == 'GET': user = User.objects.get(userid=userid) user_info = UserInfo.objects.get(userid=userid) content = {'user': user, 'user_info': user_info} detail_data = {} data = [] for detail in user_info: detail_data[’course’] = detail.course detail_data[’score’] = str(detail.score) data.append(json.dumps(detail_data, ensure_ascii=False)) content[’detail’] = data return render(request, 'user/user_info/user_info.html', content)

其中,需注意的是下面這段代碼,

(1)、定義一個空的字典為detail_data,接著再定義一個空的列表data,循環得到每個用戶信息的詳情,也就是用戶的每個課程對應的每個分數,分別把值添加進字典里面去。

(2)、后面在把字典的值通過json.dumps轉換為json格式,這樣才能給html頁面的js進行交互,而且如果有中文的話,需要在后面加個ensure_ascii=False參數,不然的話js得到的數據不是我們想得到的數據。

(3)、最后,再把轉成json的字典數據添加進列表data中,最后通過content[’detail’]=data把這個列表傳到頁面上,供js調用。

detail_data = {} data = [] for detail in user_info: detail_data[’course’] = detail.course detail_data[’score’] = str(detail.score) data.append(json.dumps(detail_data, ensure_ascii=False)) content[’detail’] = data

2、接下來看下html中如何處理上面傳過的detail數據,其中課程用下拉框依次顯示,選擇課程時動態顯示課程的分數,代碼如下:

<script> function select() { var course =$(’#course option:selected’).val(); var details = {{ detail|safe }} for(var detail in details){ var data = JSON.parse(details[detail]); if(course == data.course){ $(’#score’).html(data.score); } } } </script>

代碼解析一下:

(1)、其中獲取下拉框選擇的課程值,賦給一個變量course,接著把傳過來界面的detail,賦給一個變量details,注意這里必須要用{{ detail|safe }},不然取出來的數據會不是想要的。

(2)、接著,循環上面得到的變量,也就是一個帶有字典的列表,循環就得到每一個帶有課程和課程分數的字典,因為在view底下是把每一個字典轉換為json格式,所以現在必須把循環得到每一個字典通過json解析得到其對應的,通過JSON.parse(details[detail]),否則也是取不到對應的數據。

(3)、通過頁面下拉框選擇的課程值,跟取到的每個課程的分數做比較,相等的話,就取出對應課程的分數,填充進頁面中。

3、Django和js交互的網上例子太少,這里積累一下,以上內容僅供學習參考,謝謝!主要還是自己去嘗試。

補充知識:django 后臺數據直接交給頁面

<html><head> <title>運維平臺</title> <link rel='stylesheet' type='text/css' href='http://www.hdgsjgj.cn/static/Css/Monitor/addmqmonitor.css' rel='external nofollow' > <link rel='stylesheet' type='text/css' href='http://www.hdgsjgj.cn/static/Css/Public/header.css' rel='external nofollow' rel='external nofollow' > <link rel='stylesheet' type='text/css' href='http://www.hdgsjgj.cn/static/Css/Public/menu.css' rel='external nofollow' rel='external nofollow' ></head><body> <include file='Public:header'/> <div class='content'> <include file='Public:menu'/> <div class='con fl'> <form action='/addmqmonitor/' method='post'><label class='condition'>應用</label><input type='text' name='app' class='equipment_sz'> <label class='condition'>隊列管理器</label><input type='text' name='qmgr' class='equipment_sz'> <label class='condition'>通道名稱</label><input type='text' name='channel' class='equipment_sz'><br /> <label class='condition'>IPADDR</label><input type='text' name='ipaddr' class='equipment_sz'> <label class='condition'>PORT</label><input type='text' name='port' class='equipment_sz'> <label class='condition'>隊列監控閾值</label><input type='text' name='depth' class='equipment_sz'> <label class='condition'>是否監控</label><input type='text' name='flag' class='equipment_sz'><br /> <input type='submit' value='設備添加' class='equipment_add_btn'> </form> </div> </div></body><script type='text/javascript' src='https://rkxy.com.cn/static/Js/jquery-2.2.2.min.js'></script><!-- <script type='text/javascript' src='https://rkxy.com.cn/static/Js/Equipment/addEquipment.js'></script> --></html> def addmqmonitor(req): print req.get_full_path() app= req.POST[’app’] qmgr= req.POST[’qmgr’] channel= req.POST[’channel’] ipaddr= req.POST[’ipaddr’] port= req.POST[’port’] depth= req.POST[’depth’] flag= req.POST[’flag’] conn= MySQLdb.connect( host=’127.0.0.1’, port = 3306, user=’root’, passwd=’1234567’, db =’DEVOPS’, charset='UTF8' ) cursor = conn.cursor() sql = 'insert into mon_mq(name,qmgr,channel,ipaddr,port,depth,flag) values(’%s’,’%s’,’%s’,’%s’,’%s’,’%s’,’%s’)' % (app,qmgr,channel,ipaddr,port,depth,flag) cursor.execute(sql) conn.commit() a = cursor.execute('select name,qmgr,channel,ipaddr,port,flag from mon_mq' ) info = cursor.fetchall() print info print type(info) return render(req,’listmqinfo.html’,{’info’:info}) [root@yyjk templates]#cat listmqinfo.html <html> <head> <title>運維平臺</title> <link rel='stylesheet' type='text/css' href='http://www.hdgsjgj.cn/static/Css/Equipment/modifyBtn.css' rel='external nofollow' > <link rel='stylesheet' type='text/css' href='http://www.hdgsjgj.cn/static/Css/Public/header.css' rel='external nofollow' rel='external nofollow' > <link rel='stylesheet' type='text/css' href='http://www.hdgsjgj.cn/static/Css/Public/menu.css' rel='external nofollow' rel='external nofollow' > </head> <table border='10'>{% for x in info %} <tr><th>{{x.0}}</th><th>{{x.1}}</th><td>{{x.2}}</td><td>{{x.3}}</td><td>{{x.4}}</td><td>{{x.5}}</td></tr>{% endfor %} </table>

以上這篇Django 后臺帶有字典的列表數據與頁面js交互實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | 短信营销平台_短信群发平台_106短信发送平台-河南路尚 | SDG吸附剂,SDG酸气吸附剂,干式酸性气体吸收剂生产厂家,超过20年生产使用经验。 - 富莱尔环保设备公司(原名天津市武清县环保设备厂) | 无锡网站建设_企业网站定制-网站制作公司-阿凡达网络 | 震动筛选机|震动分筛机|筛粉机|振筛机|振荡筛-振动筛分设备专业生产厂家高服机械 | 鑫达滑石-辽宁鑫达滑石集团 | Jaeaiot捷易科技-英伟达AI显卡模组/GPU整机服务器供应商 | 儋州在线-儋州招聘找工作、找房子、找对象,儋州综合生活信息门户! | 锂电池砂磨机|石墨烯砂磨机|碳纳米管砂磨机-常州市奥能达机械设备有限公司 | 粘度计维修,在线粘度计,二手博勒飞粘度计维修|收购-天津市祥睿科技有限公司 | 科普仪器菏泽市教育教学仪器总厂 | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | 作文导航网_作文之家_满分作文_优秀作文_作文大全_作文素材_最新作文分享发布平台 | 专业广州网站建设,微信小程序开发,一物一码和NFC应用开发、物联网、外贸商城、定制系统和APP开发【致茂网络】 | 辐射色度计-字符亮度测试-反射式膜厚仪-苏州瑞格谱光电科技有限公司 | 纸塑分离机-纸塑分离清洗机设备-压力筛-碎浆机厂家金双联环保 | 自动气象站_农业气象站_超声波气象站_防爆气象站-山东万象环境科技有限公司 | 广州活动策划公司-15+年专业大型公关活动策划执行管理经验-睿阳广告 | 苏州柯瑞德货架-仓库自动化改造解决方案 | 节流截止放空阀-不锈钢阀门-气动|电动截止阀-鸿华阀门有限公司 | 低气压试验箱_高低温低气压试验箱_低气压实验箱 |林频试验设备品牌 | 百度关键词优化_网站优化_SEO价格 - 云无限好排名 | 聚合甘油__盐城市飞龙油脂有限公司 | 单柱拉力机-橡胶冲片机-哑铃裁刀-江都轩宇试验机械厂 | 火锅加盟_四川成都火锅店加盟_中国火锅连锁品牌十强_朝天门火锅【官网】 | 智能化的检漏仪_气密性测试仪_流量测试仪_流阻阻力测试仪_呼吸管快速检漏仪_连接器防水测试仪_车载镜头测试仪_奥图自动化科技 | 商标转让-购买商标专业|放心的商标交易网-蜀易标商标网 | 拉力机-拉力试验机-万能试验机-电子拉力机-拉伸试验机-剥离强度试验机-苏州皖仪实验仪器有限公司 | 医用酒精_84消毒液_碘伏消毒液等医用消毒液-漓峰消毒官网 | 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 交联度测试仪-湿漏电流测试仪-双85恒温恒湿试验箱-常州市科迈实验仪器有限公司 | 闭端端子|弹簧螺式接线头|防水接线头|插线式接线头|端子台|电源线扣+护线套|印刷电路板型端子台|金笔电子代理商-上海拓胜电气有限公司 | 神超官网_焊接圆锯片_高速钢锯片_硬质合金锯片_浙江神超锯业制造有限公司 | 企业微信scrm管理系统_客户关系管理平台_私域流量运营工具_CRM、ERP、OA软件-腾辉网络 | 电子海图系统-电梯检验系统-智慧供热系统开发-商品房预售资金监管系统 | 澳威全屋定制官网|极简衣柜十大品牌|衣柜加盟代理|全屋定制招商 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | 粘度计维修,在线粘度计,二手博勒飞粘度计维修|收购-天津市祥睿科技有限公司 | MVE振动电机_MVE震动电机_MVE卧式振打电机-河南新乡德诚生产厂家 | 翰香原枣子坊加盟费多少钱-正宗枣核糕配方培训利润高飘香 | 算命免费_生辰八字_免费在线算命 - 卜算子算命网 | 微妙网,专业的动画师、特效师、CG模型设计师网站! - wmiao.com 超声波电磁流量计-液位计-孔板流量计-料位计-江苏信仪自动化仪表有限公司 |