色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

django實現將后臺model對象轉換成json對象并傳遞給前端jquery

瀏覽:92日期:2024-05-29 08:38:57

1、django的model轉json對象。

1.1、單個modle轉換,返回json對象:

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轉換:

json_data = serializers.serialize('json', MyModel.objects.all())

2、轉換后的json對象作為子元素傳遞到前端:

2.1、將json對象轉換成字符串。(單引號包含屬性)。

objStr = json.loads(objJson)

2.2、組拼json對象。

response_data = {’statcode’: ’1’, ’data’:objStr}

2.3、返回前進行對象轉換:

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); #關鍵代碼!!!!解析一個 JSON 字符串’{'name':'John'}’為Json對象。if (res['statcode'] == '1') { objStr = res['data']; console.log(objStr['fields']['username']);#獲取方式1 alert(objStr.fields.username);#獲取方式2} }, error:function(){alert('訪問異常,請截圖聯系管理員 tn ErrorNO:auditSqlOrder.getObjById') } });

補充知識:django 將model轉換成想要的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 # 將屬性和屬性值轉換成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’

# 遍歷查詢集 調用model屬性轉換成dictdef queryset_to_json(queryset): obj_arr=[] for o in queryset:obj_arr.append(o.toDict()) return obj_arr

# 獲取角色分頁列表 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方法 然后執行查詢 得到queryset 遍歷它 將queryset里的每個model執行他的todict方法 轉換成字典格式 之后統一調用json.dumps方法轉json

以上這篇django實現將后臺model對象轉換成json對象并傳遞給前端jquery就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 99精品视频在线观看re | 91精品综合| 亚洲rct中文字幕在线 | 黄色毛片三级 | 久久香蕉国产线看观看亚洲片 | 手机日韩理论片在线播放 | 免费在线观看一区 | 亚洲成人高清在线观看 | 国产九九精品 | 久久99热久久精品91 | 亚洲欧美18v中文字幕高清 | 国产精品福利社 | 日韩在线 | 中文 | 欠草视频 | 最刺激黄a大片免费观看 | 91小视频在线观看免费版高清 | 99在线播放| 午夜91理论片 | 一级毛片视屏 | 72种姿势欧美久久久久大黄蕉 | 精品国产日韩久久亚洲 | 国产一国产一有一级毛片 | 免费一级特黄特色黄大任片 | 亚洲三区视频 | 欧美在线日韩在线 | 九一色视频| 中国性猛交xxxxx免费看 | 国产一级久久免费特黄 | 97se亚洲综合在线 | 午夜三级理论在线观看视频 | 国产精品久久人人做人人爽 | 久色精品 | 亚洲国产亚洲片在线观看播放 | 国产黄色片在线免费观看 | 毛片亚洲毛片亚洲毛片 | 成人精品亚洲 | 欧美成国产精品 | 欧美精品专区免费观看 | 精品手机在线视频 | 美国免费高清一级毛片 | 国产极品喷水视频jk制服 |