django中上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果的實(shí)現(xiàn)代碼
Django1.8.2中文文檔:Django1.8.2中文文檔
上傳圖片配置上傳文件保存目錄
1)新建上傳文件保存目錄。

2)配置上傳文件保存目錄。

后臺(tái)管理頁(yè)面上傳圖片
1)設(shè)計(jì)模型類(lèi)。
2)遷移生成表格。
3) 注冊(cè)模型類(lèi)。
后臺(tái)管理頁(yè)面上傳圖片實(shí)例
1.在static下面創(chuàng)建media文件夾(再在media文件夾里面新建booktest文件夾)。
2.設(shè)置靜態(tài)文件保存目錄
# 設(shè)置上傳文件的保存目錄 MEDIA_ROOT = os.path.join(BASE_DIR, 'static/media')
3.編寫(xiě)圖片模型類(lèi)
class PicTest(models.Model): """上傳圖片""" goods_pic = models.ImageField(upload_to='booktest') # 指定上傳圖片到media下面的booktest文件夾下
4.遷移數(shù)據(jù)
python manage.py makemigrations python manage.py migrate
如果項(xiàng)目用的是原來(lái)的數(shù)據(jù)庫(kù),那么應(yīng)該先去django_migrations里面刪除booktest的init文件;
delete from django_migrations where id = xxx;
如果數(shù)據(jù)庫(kù)中原來(lái)存在areainfo表,然后項(xiàng)目中的模型類(lèi)又申請(qǐng)創(chuàng)建,會(huì)報(bào)錯(cuò),
解決方法是去booktets/migrations/001init下面刪掉重復(fù)的表記錄。
5.去admin中注冊(cè)表
admin.site.register(models.PicTest)
這時(shí)候,就可以在后臺(tái)上傳圖片了。
用戶自定義頁(yè)面上傳圖片
1)定義用戶上傳圖片的頁(yè)面并顯示,是一個(gè)自定義的表單。
2)定義接收上傳文件的視圖函數(shù)。
request對(duì)象有一個(gè)FILES的屬性,類(lèi)似于字典,通過(guò)request.FILES可以獲取上傳文件的處理對(duì)象。
在django中,上傳文件不大于2.5M,文件放在內(nèi)存中。上傳文件大于2.5M,文件內(nèi)容寫(xiě)到一個(gè)臨時(shí)文件中。
Django處理上傳文件的兩個(gè)類(lèi):
FILE_UPLOAD_HANDLERS= ( "django.core.files.uploadhandler.MemoryFileUploadHandler", "django.core.files.uploadhandler.TemporaryFileUploadHandler")
用戶自定義頁(yè)面上傳圖片實(shí)例
上傳圖片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>
上傳圖片對(duì)應(yīng)函數(shù)
from django.conf import settings # 上傳圖片時(shí)使用
def upload_pic(request):
"""返回上傳圖片文件的頁(yè)面"""
return render(request, 'booktest/upload_pic.html')
def upload_handle(request):
"""對(duì)上傳的文件進(jìn)行處理"""
# 1.獲取上傳文件的處理對(duì)象
pic = request.FILES['pic']
pic_name = pic.name # 上傳文件名
# pic.chunk() # 上傳的文件會(huì)以迭代器的形式,一部分一部分的保存在這里面
# 2.創(chuàng)建一個(gè)文件
save_path = '%s/booktest/%s' % (settings.MEDIA_ROOT, pic_name)
# 3.將上傳的文件寫(xiě)入到新創(chuàng)建的文件中
with open(save_path, 'wb') as f:
for content in pic.chunks():
f.write(content)
# 4.記錄寫(xiě)入數(shù)據(jù)庫(kù)
models.PicTest.objects.create(goods_pic='booktest/%s' % pic_name)
# 5.返回應(yīng)答
return HttpResponse(pic_name)
配套u(yù)rl
url(r'^upload_pic', views.upload_pic), # 返回上傳圖片文件的頁(yè)面 url(r'^upload_handle', views.upload_handle), # 對(duì)上傳的文件進(jìn)行處理
分頁(yè)
需求
查詢出所有省級(jí)地區(qū)的信息,顯示在頁(yè)面上。
1)查詢出所有省級(jí)地區(qū)的信息。
2)按每頁(yè)顯示10條信息進(jìn)行分頁(yè),默認(rèn)顯示第一頁(yè)的信息,下面并顯示出頁(yè)碼。
3)點(diǎn)擊i頁(yè)鏈接的時(shí)候,就顯示第i頁(yè)的省級(jí)地區(qū)信息。
分頁(yè)實(shí)例
url
url(r'^show_areas(?P<pindex>\d*)', views.show_areas), # 分頁(yè)
show_areas.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>分頁(yè)</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 }}"><上一頁(yè)</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 }}">下一頁(yè)></a>
{% endif %}
</body>
</html>
分頁(yè)對(duì)應(yīng)函數(shù)
from django.core.paginator import Paginator
def show_areas(request, pindex):
"""分頁(yè)"""
# 1.查詢出所有省級(jí)地區(qū)的信息
areas = models.AreaInfo.objects.filter(aParent__isnull=True)
# 2.分頁(yè),每頁(yè)顯示10條
pagintor = Paginator(areas, 10)
# 3.獲取第pindex頁(yè)的內(nèi)容
if pindex == "":
# 默認(rèn)取第一頁(yè)的內(nèi)容
pindex = 1
else:
pindex = int(pindex)
# page是Page類(lèi)的實(shí)例對(duì)象
page = pagintor.page(pindex)
# 4.使用模板
return render(request, 'booktest/show_areas.html', {'page': page})
三級(jí)聯(lián)動(dòng)
需求
1)顯示省地區(qū)信息。
2)省改變時(shí)在對(duì)應(yīng)的下拉列表框中顯示下級(jí)市的信息。
3)市改變時(shí)在對(duì)應(yīng)的下拉列表框中顯示下級(jí)縣的信息。
三級(jí)聯(lián)動(dòng)實(shí)例
對(duì)應(yīng)函數(shù)
def areas(request):
return render(request, 'booktest/areas.html')
def prov(request):
"""返回省級(jí)數(shù)據(jù)"""
# 1.獲取所有省級(jí)地區(qū)的信息
areas = models.AreaInfo.objects.filter(aParent__isnull=True)
# 2.變量areas拼接處json數(shù)據(jù):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對(duì)應(yīng)地區(qū)的下級(jí)地區(qū)"""
# 1.獲取pid對(duì)應(yīng)地區(qū)的下級(jí)地區(qū)
# area = models.AreaInfo.objects.filter(id=pid)
# areas = area.areainfo_set.all()
areas = models.AreaInfo.objects.filter(aParent__id=pid)
# 2.變量areas拼接處json數(shù)據(jù):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), # 返回省級(jí)數(shù)據(jù) url(r'^city(\d+)', views.city), # 返回市級(jí)數(shù)據(jù) url(r'^dis(\d+)', views.city), # 返回縣級(jí)數(shù)據(jù)
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 () {
// 發(fā)起一個(gè)ajax請(qǐng)求/prov, 獲取所有省級(jí)地區(qū)的信息
// 獲取信息,使用get;涉及到信息修改,使用post
$.get('/prov', function (data) {
// 回調(diào)函數(shù)
// 獲取返回的json數(shù)據(jù)
let res = data.data;
// 獲取prov下拉列表框
let prov = $('#prov');
// 遍歷res數(shù)組,獲取每一個(gè)元素: [地區(qū)id,地區(qū)標(biāo)題]
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>---請(qǐng)選擇市---</option>');
let dis = $('#dis');
dis.empty().append('<option>---請(qǐng)選擇縣---</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>---請(qǐng)選擇縣---</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>---請(qǐng)選擇省---</option>
</select>
<select id="city">
<option>---請(qǐng)選擇市---</option>
</select>
<select id="dis">
<option>---請(qǐng)選擇縣---</option>
</select>
</body>
</html>
總結(jié)
以上所述是小編給大家介紹的django中上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
為什么說(shuō)python適合寫(xiě)爬蟲(chóng)
在本文中,小編給讀者們整理的一篇關(guān)于分析為什么說(shuō)python適合寫(xiě)爬蟲(chóng)的語(yǔ)言的相關(guān)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2020-06-06
Python?作為小程序后端的三種實(shí)現(xiàn)方法(推薦)
這篇文章主要介紹了Python?作為小程序后端的三種方法,在這比較推薦前兩種方法,本文通過(guò)實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
python實(shí)現(xiàn)類(lèi)似ftp傳輸文件的網(wǎng)絡(luò)程序示例
這篇文章主要介紹了python實(shí)現(xiàn)類(lèi)似ftp傳輸文件的網(wǎng)絡(luò)程序示例,需要的朋友可以參考下2014-04-04
利用python實(shí)現(xiàn)萬(wàn)年歷的查詢
本篇文章主要給大家分享的是python實(shí)現(xiàn)萬(wàn)年歷的查詢,利用python做能夠?qū)崿F(xiàn)萬(wàn)年歷查詢的一個(gè)小功能,感興趣的小伙伴可以參考一下2021-10-10
Python基本結(jié)構(gòu)之判斷語(yǔ)句的用法詳解
在程序的設(shè)計(jì)當(dāng)中,代碼并不是逐步按照順序進(jìn)行執(zhí)行的,在運(yùn)行到某一行代碼當(dāng)中,需要停下進(jìn)行判斷接下來(lái)將要運(yùn)行到那一個(gè)分支代碼,這種判斷就代表的是分支結(jié)構(gòu)。分支結(jié)構(gòu)是可以使用?if?語(yǔ)句來(lái)進(jìn)行判斷的,而我們本篇博客講的也是?if?語(yǔ)句,需要的可以了解一下2022-07-07
在macOS上搭建python環(huán)境的實(shí)現(xiàn)方法
今天小編就為大家分享一篇在macOS上搭建python環(huán)境的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08
最近Python有點(diǎn)火? 給你7個(gè)學(xué)習(xí)它的理由!
最近Python有點(diǎn)火?這篇文章主要為大家分享了7個(gè)你現(xiàn)在就該學(xué)習(xí)Python的理由,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
Python計(jì)時(shí)相關(guān)操作詳解【time,datetime】
這篇文章主要介紹了Python計(jì)時(shí)相關(guān)操作,涉及time,datetime模塊的使用技巧,包括時(shí)間戳、時(shí)間差、日期格式等操作方法,需要的朋友可以參考下2017-05-05

