django中上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果的實(shí)現(xiàn)代碼
Django1.8.2中文文檔:Django1.8.2中文文檔
上傳圖片配置上傳文件保存目錄
1)新建上傳文件保存目錄。
2)配置上傳文件保存目錄。
后臺(tái)管理頁(yè)面上傳圖片
1)設(shè)計(jì)模型類。
2)遷移生成表格。
3) 注冊(cè)模型類。
后臺(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.編寫圖片模型類
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)目用的是原來的數(shù)據(jù)庫(kù),那么應(yīng)該先去django_migrations里面刪除booktest的init文件;
delete from django_migrations where id = xxx;
如果數(shù)據(jù)庫(kù)中原來存在areainfo表,然后項(xiàng)目中的模型類又申請(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的屬性,類似于字典,通過request.FILES可以獲取上傳文件的處理對(duì)象。
在django中,上傳文件不大于2.5M,文件放在內(nèi)存中。上傳文件大于2.5M,文件內(nèi)容寫到一個(gè)臨時(shí)文件中。
Django處理上傳文件的兩個(gè)類:
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.將上傳的文件寫入到新創(chuàng)建的文件中 with open(save_path, 'wb') as f: for content in pic.chunks(): f.write(content) # 4.記錄寫入數(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類的實(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ì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
詳解python os.path.exists判斷文件或文件夾是否存在
這篇文章主要介紹了詳解python os.path.exists判斷文件或文件夾是否存在,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11python判斷字符串以什么結(jié)尾的實(shí)例方法
在本篇文章里小編給大家整理了關(guān)于python判斷字符串以什么結(jié)尾的實(shí)例方法 ,需要的朋友們可以學(xué)習(xí)參考下。2020-09-09Python實(shí)戰(zhàn)基礎(chǔ)之繪制餅狀圖分析商品庫(kù)存
餅狀圖(pie chart)一般用于描述分類型數(shù)據(jù)的相對(duì)頻數(shù)或百分?jǐn)?shù)頻數(shù)分布,呈現(xiàn)部分與總體的關(guān)系,下面這篇文章主要給大家介紹了關(guān)于Python實(shí)戰(zhàn)基礎(chǔ)之繪制餅狀圖分析商品庫(kù)存的相關(guān)資料,需要的朋友可以參考下2022-07-07在Python的Flask框架中實(shí)現(xiàn)單元測(cè)試的教程
這篇文章主要介紹了在Python的Flask框架中實(shí)現(xiàn)單元測(cè)試的教程,屬于自動(dòng)化部署的方面,可以給debug工作帶來諸多便利,需要的朋友可以參考下2015-04-04Python中關(guān)于面向?qū)ο笾欣^承的詳細(xì)講解
面向?qū)ο缶幊?(OOP) 語(yǔ)言的一個(gè)主要功能就是“繼承”。繼承是指這樣一種能力:它可以使用現(xiàn)有類的所有功能,并在無需重新編寫原來的類的情況下對(duì)這些功能進(jìn)行擴(kuò)展2021-10-10python詞云庫(kù)wordCloud使用方法詳解(解決中文亂碼)
這篇文章主要介紹了python詞云庫(kù)wordCloud使用方法詳解(解決中文亂碼),需要的朋友可以參考下2020-02-02利用Python爬蟲爬取金融期貨數(shù)據(jù)的案例分析
從技術(shù)角度來看,經(jīng)過一步步解析,任務(wù)是簡(jiǎn)單的,入門requests爬蟲及入門pandas數(shù)據(jù)分析就可以完成,本文重點(diǎn)給大家介紹Python爬蟲爬取金融期貨數(shù)據(jù)的案例分析,感興趣的朋友一起看看吧2022-06-06Python遍歷目錄下文件、讀取、千萬條數(shù)據(jù)合并詳情
這篇文章主要介紹了Python遍歷目錄下文件、讀取、千萬條數(shù)據(jù)合并詳情,對(duì)文件夾和文件進(jìn)行屬性判斷,首先對(duì)文件夾進(jìn)行遍歷,看文件夾里有什么樣的文件,讀取出文件夾中的所有文件,下面文章將詳細(xì)介紹該內(nèi)容,需要的小伙伴可以參考一下2022-01-01python實(shí)現(xiàn)探測(cè)socket和web服務(wù)示例
這篇文章主要介紹了python實(shí)現(xiàn)探測(cè)socket和web服務(wù)示例,需要的朋友可以參考下2014-03-03