Django1.8.2中文文档:Django1.8.2中文文档

上传图片

配置上传文件保存目录

1)新建上传文件保存目录。

2)配置上传文件保存目录。

后台管理页面上传图片

  • 1)设计模型类。
  • 2)迁移生成表格。
  • 3) 注册模型类。

后台管理页面上传图片实例

1.在static下面创建media文件夹(再在media文件夹里面新建booktest文件夹)。

2.设置静态文件保存目录

# 设置上传文件的保存目录
MEDIA_ROOT = os.path.join(BASE_DIR, 'static/media')

3.编写图片模型类

class PicTest(models.Model):
"""上传图片"""
goods_pic = models.ImageField(upload_to='booktest') # 指定上传图片到media下面的booktest文件夹下

4.迁移数据

python manage.py makemigrations
python manage.py migrate

如果项目用的是原来的数据库,那么应该先去django_migrations里面删除booktest的init文件;

delete from django_migrations where id = xxx;

如果数据库中原来存在areainfo表,然后项目中的模型类又申请创建,会报错,
解决方法是去booktets/migrations/001init下面删掉重复的表记录。

5.去admin中注册表

admin.site.register(models.PicTest)

这时候,就可以在后台上传图片了。

用户自定义页面上传图片

  • 1)定义用户上传图片的页面并显示,是一个自定义的表单。
  • 2)定义接收上传文件的视图函数。

request对象有一个FILES的属性,类似于字典,通过request.FILES可以获取上传文件的处理对象

在django中,上传文件不大于2.5M,文件放在内存中。上传文件大于2.5M,文件内容写到一个临时文件中。
Django处理上传文件的两个类:

FILE_UPLOAD_HANDLERS= (
"django.core.files.uploadhandler.MemoryFileUploadHandler",
"django.core.files.uploadhandler.TemporaryFileUploadHandler")

用户自定义页面上传图片实例

上传图片html--upload_pic.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>上传图片</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<form action="/upload_handle/" method="post" enctype="multipart/form-data">
{% csrf_token %}
<input type="file" name="pic"><br>
<input type="submit" value="上传图片">
</form> </body>
</html>

上传图片对应函数

from django.conf import settings  # 上传图片时使用
def upload_pic(request):
"""返回上传图片文件的页面"""
return render(request, 'booktest/upload_pic.html') def upload_handle(request):
"""对上传的文件进行处理"""
# 1.获取上传文件的处理对象
pic = request.FILES['pic']
pic_name = pic.name # 上传文件名
# pic.chunk() # 上传的文件会以迭代器的形式,一部分一部分的保存在这里面
# 2.创建一个文件
save_path = '%s/booktest/%s' % (settings.MEDIA_ROOT, pic_name)
# 3.将上传的文件写入到新创建的文件中
with open(save_path, 'wb') as f:
for content in pic.chunks():
f.write(content)
# 4.记录写入数据库
models.PicTest.objects.create(goods_pic='booktest/%s' % pic_name)
# 5.返回应答
return HttpResponse(pic_name)

配套url

url(r'^upload_pic', views.upload_pic),  # 返回上传图片文件的页面
url(r'^upload_handle', views.upload_handle), # 对上传的文件进行处理

分页

需求

查询出所有省级地区的信息,显示在页面上。
1)查询出所有省级地区的信息。
2)按每页显示10条信息进行分页,默认显示第一页的信息,下面并显示出页码。
3)点击i页链接的时候,就显示第i页的省级地区信息。

分页实例

url

url(r'^show_areas(?P<pindex>\d*)', views.show_areas),  # 分页

show_areas.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>分页</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body> <ul>
{% for area in page %}
<li>{{ area.atitle }}</li>
{% endfor %}
</ul> {% if page.has_previous %}
<a href="/show_areas{{ page.previous_page_number }}">&lt;上一页</a>
{% endif %} {% for pindex in page.paginator.page_range %}
{% if pindex == page.number %}
{{ pindex }}
{% else %}
<a href="/show_areas{{ pindex }}">{{ pindex }}</a>
{% endif %}
{% endfor %} {% if page.has_next %}
<a href="/show_areas{{ page.next_page_number }}">下一页&gt;</a>
{% endif %} </body>
</html>

分页对应函数

from django.core.paginator import Paginator

def show_areas(request, pindex):
"""分页"""
# 1.查询出所有省级地区的信息
areas = models.AreaInfo.objects.filter(aParent__isnull=True)
# 2.分页,每页显示10条
pagintor = Paginator(areas, 10)
# 3.获取第pindex页的内容
if pindex == "":
# 默认取第一页的内容
pindex = 1
else:
pindex = int(pindex)
# page是Page类的实例对象
page = pagintor.page(pindex) # 4.使用模板
return render(request, 'booktest/show_areas.html', {'page': page})

三级联动

需求

1)显示省地区信息。
2)省改变时在对应的下拉列表框中显示下级市的信息。
3)市改变时在对应的下拉列表框中显示下级县的信息。

三级联动实例

对应函数

def areas(request):
return render(request, 'booktest/areas.html') def prov(request):
"""返回省级数据"""
# 1.获取所有省级地区的信息
areas = models.AreaInfo.objects.filter(aParent__isnull=True)
# 2.变量areas拼接处json数据:atitle,id
areas_list = []
for area in areas:
areas_list.append((area.id, area.atitle))
return JsonResponse({'data': areas_list}) def city(request, pid):
"""获取pid对应地区的下级地区"""
# 1.获取pid对应地区的下级地区
# area = models.AreaInfo.objects.filter(id=pid)
# areas = area.areainfo_set.all()
areas = models.AreaInfo.objects.filter(aParent__id=pid)
# 2.变量areas拼接处json数据:atitle,id
areas_list = []
for area in areas:
areas_list.append((area.id, area.atitle))
return JsonResponse({'data': areas_list})

url

url(r'^prov', views.prov),  # 返回省级数据
url(r'^city(\d+)', views.city), # 返回市级数据
url(r'^dis(\d+)', views.city), # 返回县级数据

area.html

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>省市县案例</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<script src="/static/js/jquery-3.3.1.js"></script>
<script>
$(function () {
// 发起一个ajax请求/prov, 获取所有省级地区的信息
// 获取信息,使用get;涉及到信息修改,使用post
$.get('/prov', function (data) {
// 回调函数
// 获取返回的json数据
let res = data.data;
// 获取prov下拉列表框
let prov = $('#prov');
// 遍历res数组,获取每一个元素: [地区id,地区标题]
for(let i=0; i<res.length; i++) {
let id = res[i][0];
let atitle = res[i][1];
let option_str = "<option value='"+ id +"'>" + atitle + "</option>";
// 向prov下拉列表框中追加元素
prov.append(option_str)
}
}); // 绑定prov下拉框的change事件,获取省下面市的信息
$('#prov').change(function () {
let prov_id = $(this).val();
$.get('/city'+prov_id, function (data) {
let res = data.data;
let city = $('#city');
city.empty().append('<option>---请选择市---</option>');
let dis = $('#dis');
dis.empty().append('<option>---请选择县---</option>');
$.each(res, function (index, item) {
let id = item[0];
let atitle = item[1];
let option_str = "<option value='"+ id +"'>" + atitle + "</option>";
// 向city下拉列表框中追加元素
city.append(option_str)
})
})
}); // 绑定prov下拉框的change事件,获取省下面市的信息
$('#city').change(function () {
let city_id = $(this).val();
$.get('/dis'+city_id, function (data) {
let res = data.data;
let dis = $('#dis');
dis.empty().append('<option>---请选择县---</option>');
$.each(res, function (index, item) {
let id = item[0];
let atitle = item[1];
let option_str = "<option value='"+ id +"'>" + atitle + "</option>";
// 向city下拉列表框中追加元素
dis.append(option_str)
})
})
});
})
</script>
</head>
<body>
<select id="prov">
<option>---请选择省---</option> </select>
<select id="city">
<option>---请选择市---</option>
</select>
<select id="dis">
<option>---请选择县---</option>
</select>
</body>
</html>

Django之上传图片,分页,三级联动的更多相关文章

  1. Django积木块八——三级联动

    三级联动 前端需要的效果,省之后市之后现,创建model,查询所有的省的信息,json传到前面,之后通过省的id找到对应的市,是用异步实现的. # model class Sheng(models.M ...

  2. django项目中cxselect三级联动

    下载cxselect插件放在static文件夹下 前端引入 <script src="/static/js/jQuery-1.8.2.min.js"></scri ...

  3. Django Admin实现三级联动(省市区)

    通过自定义Admin的模板文件实现省市区的三级联动.要求创建记录时,根据省>市>区的顺序选择依次显示对应数据. 修改记录时默认显示已存在的数据. Model class Member(mo ...

  4. Django Admin 实现三级联动的示例代码(省市区)===>小白级

    一  使用环境 开发系统: windows IDE: pycharm 数据库: msyql,navicat 编程语言: python3.7  (Windows x86-64 executable in ...

  5. 在使用ajax实现三级联动调用数据库数据并通过调出的数据进行二级表单查询

    在使用ajax实现三级联动查询数据库数据后再使用ajax无刷新方式使用三级联动调出的数据进行二级查询 但是现在遇到问题,在二级查询的时候期望是将数据以表格的形式展示在三级联动的下方,但是现在在查询后会 ...

  6. 2019.03.25 Ajax三级联动

    所谓三级联动就是,一层接着一层,根据上一层的选择给出这一层的结果 如选择市之后,会给出相应的区,然后到相应的县这就是联动 配置视图 ​from django.core import serialize ...

  7. js封装的三级联动菜单(使用时只需要一行js代码)

    前言 在实际的项目开发中,我们经常需要三级联动,比如省市区的选择,商品的三级分类的选择等等. 而网上却找不到一个代码完整.功能强大.使用简单的三级联动菜单,大都只是简单的讲了一下实现思路. 下面就给大 ...

  8. 利用select实现年月日三级联动的日期选择效果

    × 目录 [1]演示 [2]规划 [3]结构生成[4]算法处理 前面的话 关于select控件,可能年月日三级联动的日期选择效果是最常见的应用了.本文是选择框脚本的实践,下面将对日期选择效果进行详细介 ...

  9. jQuery省市区三级联动插件

    体验效果:http://hovertree.com/texiao/bootstrap/4/支持PC和手机移动端. 手机扫描二维码体验效果: 代码如下: <!DOCTYPE html> &l ...

随机推荐

  1. 关于页面scroolTop的获取

    scroolTop 发现问题 获取页面滚动高度的时候: 当html页面设置了DTD<!DOCTYPE html> document.body.scroolTop // 值总是为0: doc ...

  2. 我对微服务、SpringCloud、k8s、Istio的一些杂想

    一.微服务与SOA “微服务”是一个名词,没有这个名词之前也有“微服务”,一个朗朗上口的名词能让大家产生一个认知共识,这对推动一个事务的发展挺重要的,不然你叫微服务他叫小服务的大家很难集中到一个点上. ...

  3. 第一章: 初识Java

    计算机程序:计算机为完成某些功能产生的一系列有序指令集合. Java技术包括:JavaSE(标准版) JavaEE(企业版) ---JavaME(移动版) 开发Java程序步骤:1.编写 2.编译 3 ...

  4. @Validated和@Valid的区别?校验级联属性(内部类)

    每篇一句 NBA里有两大笑话:一是科比没天赋,二是詹姆斯没技术 相关阅读 [小家Java]深入了解数据校验:Java Bean Validation 2.0(JSR303.JSR349.JSR380) ...

  5. 19个心得,明明白白说Linux下的负载均衡

    一.目前网站架构一般分成负载均衡层.web层和数据库层,我其实一般还会多加一层,即文件服务器层,因为现在随着网站的PV越来越多,文件服务器的压力也越来越大;不过随着moosefs.DRDB+Heart ...

  6. 【Android】Field requires API level 4 (current min is 1): android.os.Build.VERSION#SDK_INT

    刚遇到了这个问题: Field requires API level 4 (current min is 1): android.os.Build.VERSION#SDK_INT 解决方法: 修改 A ...

  7. 树莓派 + Windows IoT Core 搭建环境监控系统

    前言:Windows IoT 是微软为嵌入式开发板设计的一种物联网操作系统,运行Windows UWP(C# 开发),可以设计出丰富的交互界面,驱动GPIO,连接一些传感器做有意思的事,本文详细介绍如 ...

  8. python虚拟环境完美部署

    一.前言 预处理 建议仔细看完本文章之后在进行操作,避免失误,本环境可以用于生产环境,有利于生产环境python之间的环境隔离,互相不会产生环境冲突:pyenv和pyenv-virtualenv可以完 ...

  9. 4如何用PHP给MySQL数据库添加记录

    首先连接数据库(依旧用第二篇的方法) 假设数据库表里只有id,name,email三列 添加以下代码 $inputemail=写你要的email;$inputname=写你要的name;//先设定你要 ...

  10. windwos环境下安装python2和python3

    一 python安装 下载地址: https://www.python.org/downloads/ 环境变量:Path中添加C:\Python27\Scripts\;C:\Python27\; C: ...