您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關django中如何實現上傳圖片分頁三級聯動效果的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
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 }}"><上一頁</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 }}">下一頁></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中如何實現上傳圖片分頁三級聯動效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。