91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

django中如何實現上傳圖片分頁三級聯動效果

發布時間:2021-07-20 09:19:21 來源:億速云 閱讀:183 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關django中如何實現上傳圖片分頁三級聯動效果的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

Django1.8.2中文文檔:Django1.8.2中文文檔

上傳圖片配置上傳文件保存目錄

1)新建上傳文件保存目錄。

django中如何實現上傳圖片分頁三級聯動效果

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

django中如何實現上傳圖片分頁三級聯動效果

后臺管理頁面上傳圖片

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中如何實現上傳圖片分頁三級聯動效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西盟| 无锡市| 大连市| 齐河县| 徐闻县| 兴隆县| 柏乡县| 开阳县| 凤阳县| 晴隆县| 平乡县| 太康县| 景洪市| 山西省| 曲阜市| 印江| 屏东县| 六安市| 武汉市| 巴青县| 延川县| 唐山市| SHOW| 称多县| 清原| 衡水市| 甘泉县| 镇原县| 紫金县| 封丘县| 朔州市| 绥阳县| 岳西县| 莎车县| 江陵县| 定远县| 定日县| 福州市| 渭南市| 淮阳县| 绵竹市|