内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

蘿北ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書(shū)銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書(shū)合作)期待與您的合作!

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

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

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

django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果

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

django中如何實(shí)現(xiàn)上傳圖片分頁(yè)三級(jí)聯(lián)動(dòng)效果

后臺(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 }}">&lt;上一頁(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è)&gt;</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)

h5響應(yīng)式網(wǎng)站建設(shè)
乌审旗| 秦皇岛市| 故城县| 蒲城县| 昌平区| 包头市| 黄陵县| 苗栗县| 眉山市| 长葛市| 庆云县| 连平县| 蓬莱市| 教育| 天峻县| 毕节市| 天柱县| 吉木萨尔县| 中方县| 青铜峡市| 囊谦县| 苍山县| 乌兰县| 清河县| 德安县| 阆中市| 彭阳县| 阳西县| 娄底市| 肃宁县| 长春市| 临漳县| 英超| 镇赉县| 班戈县| 泽库县| 比如县| 青冈县| 绩溪县| 龙门县| 遂川县|