首页>>后端>>Python->django如何将数据传到前端(2023年最新解答)

django如何将数据传到前端(2023年最新解答)

时间:2023-12-25 本站 点击:0

导读:很多朋友问到关于django如何将数据传到前端的相关问题,本文首席CTO笔记就来为大家做个详细解答,供大家参考,希望对大家有所帮助!一起来看看吧!

python+django 如何把一个底层的数据传到页面上?

举个例子:数据库有 User表,它有姓名、年龄字段,需要在页面展示

#.py

def test(request):

#从数据库里查数据

user=User.objects.get(id=1)

return render_to_response('test.html',{'user':user},context_instance = RequestContext(request))

#.html

......

姓名:{{user.name}}

年龄:{{user.age}}

......

django 传对象到前端 class类型怎么取

如果是django内置的模板引擎,

例如class A,实例a,a中的属性name,

则{{a}}为实例a, {{a.name}}为取name值

Django怎么把py文件画出来的图像传到前端

Django把py文件画出来的图像传到前端,努力looks去,嗯啦看上去模型,阿狸入魔无情人啊咯恶心里去了。

如何数据库数据到前端

首先你需要掌握的是数据库查询语句,这里使用最简单的数据库查询语句:SELECT * FROM sys_role,表示从角色表中查询出所有的信息,下面展示的是查询结果,这个结果需要展示到前端页面则需要代码调用这个sql语句

请点击输入图片描述

在applicationContext.xml(spring mvc的配置文件)中配置数据库连接池,保证数据的正常连接,这里需要注意连接ip和数据库名称

请点击输入图片描述

首先在控制层(逻辑处理层)中调用后台查询函数,然后返回到页面,因为数据库可能比较大,所以需要使用分页工具,保证内存容量

请点击输入图片描述

业务逻辑层,一般情况下是实现接口的,这里是实现类,实现业务的分发,这里需要调用数据库Dao层的方法

请点击输入图片描述

最后在mybatis的配置文件中写入mybatis的查询语句,然后封装成方法,这里与最初的SELECT * FROM sys_role不同,主要是加了分页(limit)和排序功能(order by)

请点击输入图片描述

最后回到jsp页面,根据之前的控制层页面输出,我们需要写一个role.jsp的文件,该文件主要遍历查询出来的数据,遍历采用c标签的形式

请点击输入图片描述

7

最后使用前端页面框架就可以展示出像下面这样的前端样式展示

请点击输入图片描述

django-restful:与前端vue接口对接

category 与vue 接口对接

首先是需要把所有的category的内容取出来

由于前端vue展示category是分级的

一级 二级 三级 这样展示的

所以我们需要把三个内容都拿出来

但是首先需要取出第一级 然后第一级镶嵌了第二级,然后第二级镶嵌第三季 ,就跟上面goods中显示外键的category的内容一样

我们还是需要写serializer

这样就是一级 镶嵌二级 二级镶嵌三级

但是这里有一个问题不要搞错了 这三个类的位置不能弄错了

因为一级是调用二级 所以二级一定是先写好了的

所以二级一定在一级上面 同理 三级要在二级上面

然后就是view

在过滤中加上category_type = 1 这样就可以直接显示第一大类 然后第一大类中有第二小类 这样更有层次感 如果直接一下子全部取出来 就不好分辨了

同时我们还要处理取出某个单一的信息

所以 我们继承了mixins.RetrieveModelMixin 这个类,这是一个显示详情的类

例如显示某个动物园的某个动物那样

/zoos/id

这样的url

同样这样写了 我们就直接只配置category的url就够了

就不用考虑 后面的id是否还需要配置一个url 这些都不用考虑了,因为我们继承了 viewset这个类

这些问题他都帮我们解决了

这样处理我们后端就能看见了

但是这样处理了 前端对接时 会发现 无法显示

因为有一个跨域问题

这个问题前后端 都可以独自解决 这里学习的是后端,所以讲一下后端的做法

就是修改服务端

在github上搜索django-cors-headers就可以找到这个信息

同样里面介绍如何使用

安装

pip install django-cors-headers

然后settins中INSTALLED_APPS配置和settings中MIDDLEWARE配置

这里要注意 MIDDLEWARE配置中

'corsheaders.middleware.CorsMiddleware',

'django.middleware.common.CommonMiddleware',

这两个必须放在

'django.middleware.csrf.CsrfViewMiddleware',

这个的前面 不然会报错

同时还要配置

CORS_ORIGIN_ALLOW_ALL = True

允许跨域访问 它默认是False

这样前端就可以正常显示了

为什么会产生跨域访问

因为vue中api配置的中 我们调试数据 不可能把所有的host 都修改了 有一些是线上数据 我们调试的是本地的一部分数据 所以要重新定一个localhost

修改部分 host的链接

这样就导致了跨域 本身使用的是一个线上host端口,但是数据中有一部分是请求的是本地host端口 导致了跨域访问

Django接受前端数据的几种方法

字符型

字符型的数据相对好获取,前端传递的方法如下:

sendData = {
 "exporttype": exporttype,

"bugids": bugids,

"test": JSON.stringify({"test": "test"})

};

在Django的后端只要使用exporttype = request.GET.get("exporttype")

就能正常的获取到这个数据了。

注意: 在Python2.7中数据是unicode编码的,如果要使用,有时候需要进行转str

结果示例:

Excle type 'unicode'

数组型

获取数组型的数据如果使用获取字符串的数据的方法,打出的结果是None。我们要使用这个方法:

bugids = request.GET.getlist("bugids[]")

这样获取的数据就是数组类型。

注意: 获取的数组中的元素是unicode编码的,在某些时候使用需要转编码

结果示例:

•传递的url

[14/Jul/2016 11:00:41]"GET /testtools/exportbug/?exporttype=Exclebugids%5B%5D=102bugids%5B%5D=101bugids%5B%5D

•获取的数据

[u'102', u'101', u'100', u'99', u'98', u'97', u'96', u'95', u'94', u'93', u'92', u'91', u'90', u'89', u'88', u'87'

字典型

字典型数据其实可以当成字符串数据来处理,获取到对应字符串后使用JSON模块做一下格式化就行了。

对于前端来说,传递字典型的数据就是传递JSON数据,所以使用的方法是:

"test": JSON.stringify({"test": "test"})

结果示例:

{"test":"test"} type 'unicode'

相关源码

•Get方法

Get方法是wsgi里面的一个方法。

def GET(self):

# The WSGI spec says 'QUERY_STRING' may be absent.

raw_query_string = get_bytes_from_wsgi(self.environ, 'QUERY_STRING', '')

return http.QueryDict(raw_query_string, encoding=self._encoding)

最终返回的是一个http.QueryDict(raw_query_string, encoding=self._encoding)http的原始数据,而QueryDict继承于MultiValueDict ,所以我们直接看MultiValueDict就好了。

•MultiValueDict

其实源码看起来并不难。

def get(self, key, default=None):

"""

Returns the last data value for the passed key. If key doesn't exist

or value is an empty list, then default is returned.

"""

try:

val = self[key]

except KeyError:

return default

if val == []:

return default

return val

def getlist(self, key, default=None):

"""

Returns the list of values for the passed key. If key doesn't exist,

then a default value is returned.

"""

try:

return super(MultiValueDict, self).__getitem__(key)

except KeyError:

if default is None:

return []

return default

def __getitem__(self, key):

"""

Returns the last data value for this key, or [] if it's an empty list;

raises KeyError if not found.

"""

try:

list_ = super(MultiValueDict, self).__getitem__(key)

except KeyError:

raise MultiValueDictKeyError(repr(key))

try:

return list_[-1]

except IndexError:

return []

结语:以上就是首席CTO笔记为大家整理的关于django如何将数据传到前端的相关内容解答汇总了,希望对您有所帮助!如果解决了您的问题欢迎分享给更多关注此问题的朋友喔~


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Python/59798.html