這篇文章給大家分享的是有關(guān)django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
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.編寫(xiě)圖片模型類
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)目中的模型類又申請(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的屬性,類似于字典,通過(guò)request.FILES可以獲取上傳文件的處理對(duì)象。
在django中,上傳文件不大于2.5M,文件放在內(nèi)存中。上傳文件大于2.5M,文件內(nèi)容寫(xiě)到一個(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.將上傳的文件寫(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類的實(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>
感謝各位的閱讀!關(guān)于“django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
文章名稱:django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果-創(chuàng)新互聯(lián)
文章位置:http://www.rwnh.cn/article46/dohshg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、軟件開(kāi)發(fā)、ChatGPT、移動(dòng)網(wǎng)站建設(shè)、小程序開(kāi)發(fā)、全網(wǎng)營(yíng)銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容