django實(shí)現(xiàn)將后臺(tái)model對(duì)象轉(zhuǎn)換成json對(duì)象并傳遞給前端jquery
1、django的model轉(zhuǎn)json對(duì)象。
1.1、單個(gè)modle轉(zhuǎn)換,返回json對(duì)象:
sqlOrder = get_object_or_404(SqlOrder,id=request.GET.get('id'))objJson = serialize(’json’,[sqlOrder])[1:-1]{'model': 'sqlapply.sqlorder', 'pk': 2, 'fields': {'work_id': '{now}{_ran}', 'username': 'admin', 'status': 3, 'type': 0, 'backup': 0}}
注意:objJson['fields']['username'] 才能獲得想要屬性值。objJson['pk']獲得主鍵值。
1.2、querySet轉(zhuǎn)換:
json_data = serializers.serialize('json', MyModel.objects.all())
2、轉(zhuǎn)換后的json對(duì)象作為子元素傳遞到前端:
2.1、將json對(duì)象轉(zhuǎn)換成字符串。(單引號(hào)包含屬性)。
objStr = json.loads(objJson)
2.2、組拼json對(duì)象。
response_data = {’statcode’: ’1’, ’data’:objStr}
2.3、返回前進(jìn)行對(duì)象轉(zhuǎn)換:
return HttpResponse(json.dumps(response_data))
2.4、前端接受并獲取:
$.ajax({ url: '{% url ’sqlapply:auditSqlOrder’ %}', type:'GET', data:{'id':id,'args':'getObjById'}, success:function(result){res = jQuery.parseJSON(result); #關(guān)鍵代碼!!!!解析一個(gè) JSON 字符串’{'name':'John'}’為Json對(duì)象。if (res['statcode'] == '1') { objStr = res['data']; console.log(objStr['fields']['username']);#獲取方式1 alert(objStr.fields.username);#獲取方式2} }, error:function(){alert('訪問異常,請(qǐng)截圖聯(lián)系管理員 tn ErrorNO:auditSqlOrder.getObjById') } });
補(bǔ)充知識(shí):django 將model轉(zhuǎn)換成想要的json格式
model:
class SysRole(models.Model): id = models.CharField(db_column=’ID’, primary_key=True, max_length=50) # Field name made lowercase. rolename = models.CharField(db_column=’RoleName’, max_length=50) # Field name made lowercase. description = models.CharField(db_column=’Description’, max_length=200, blank=True, null=True) # Field name made lowercase. querycode = models.CharField(db_column=’QueryCode’, max_length=200, blank=True, null=True) # Field name made lowercase. isdisabled = models.CharField(db_column=’IsDisabled’) # Field name made lowercase. This field type is a guess. def __unicode__(self): return self.rolename # 將屬性和屬性值轉(zhuǎn)換成dict 列表生成式 def toDict(self): return dict([(attr, getattr(self, attr)) for attr in [f.name for f in self._meta.fields]])#type(self._meta.fields).__name__ class Meta: managed = False db_table = ’sys_role’
# 遍歷查詢集 調(diào)用model屬性轉(zhuǎn)換成dictdef queryset_to_json(queryset): obj_arr=[] for o in queryset:obj_arr.append(o.toDict()) return obj_arr
# 獲取角色分頁(yè)列表 def get_roles_page(self,_page,_limit): _roles = SysRole.objects.all()[(int(_page)-1)*int(_limit):int(_page)*int(_limit)] _count = SysRole.objects.all().count() _dict_roles = tools.queryset_to_json(_roles) _data_page_json = {} _data_page_json[’Rows’]=_dict_roles _data_page_json[’Total’]=_count return json.dumps(_data_page_json,ensure_ascii=False)
在model上加入toDict方法 然后執(zhí)行查詢 得到queryset 遍歷它 將queryset里的每個(gè)model執(zhí)行他的todict方法 轉(zhuǎn)換成字典格式 之后統(tǒng)一調(diào)用json.dumps方法轉(zhuǎn)json
以上這篇django實(shí)現(xiàn)將后臺(tái)model對(duì)象轉(zhuǎn)換成json對(duì)象并傳遞給前端jquery就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. CSS hack用法案例詳解2. input submit、button和回車鍵提交數(shù)據(jù)詳解3. PHP字符串前后字符或空格刪除方法介紹4. 使用HttpClient消費(fèi)ASP.NET Web API服務(wù)案例5. Jsp+Servlet實(shí)現(xiàn)文件上傳下載 刪除上傳文件(三)6. 詳解盒子端CSS動(dòng)畫性能提升7. ASP.NET Core實(shí)現(xiàn)中間件的幾種方式8. ASP常用日期格式化函數(shù) FormatDate()9. 詳解瀏覽器的緩存機(jī)制10. JSP servlet實(shí)現(xiàn)文件上傳下載和刪除
