电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

django中ImageField的使用詳解

瀏覽:164日期:2024-09-14 17:46:09
ImageField的使用筆記

今天完善作業(yè)寫的訂單系統(tǒng),主要是給每一個菜品增加圖片,看起來美觀一些,但是沒想到這個小小的需求花了我一天時間,記錄下來,算增長知識了。

使用流程1.配置setting文件

MEDIA_ROOT代表的是上傳圖片的根目錄,MEDIA_URL代表的是訪問文件時url的前綴。

# 圖片儲存根路徑MEDIA_ROOT = join(’media’)# 圖片訪問urlMEDIA_URL = ’/IMG/’2.model里面增加ImageField屬性

up_load一定要配置,代表你最后的圖片會存儲到MEDIA_ROOT/up_load(實際上是你賦予的名稱)這個文件夾中。

class Menu(models.Model): ''' 餐品數(shù)據(jù)庫 ''' ID = models.BigAutoField(primary_key=True,editable=False) lastEditTime = models.DateTimeField(auto_now_add=True) merchantID = models.ForeignKey(Usr, verbose_name='商家賬號', on_delete=models.CASCADE,to_field=’ID’) itemName = models.CharField(max_length=20,verbose_name='餐品名') itemText = models.TextField(verbose_name='餐品簡介') price = models.FloatField(verbose_name='餐品價格') ################# up_load代表你上傳圖片所存儲的文件夾名字 picture = models.ImageField(verbose_name=’餐品圖片’,null=True,upload_to=’img/’) class Meta: db_table = 'Menu' verbose_name = '餐品數(shù)據(jù)表' ordering=[’-lastEditTime’]3.Form表單類

本項目使用的是django自帶的Form表單類進行數(shù)據(jù)的傳遞。

class MerchantDish(forms.Form): ''' 商家菜品提交表單 ''' itemName = forms.CharField(max_length=20,label='餐品名') itemText = forms.CharField(max_length=300,label='餐品簡介') price = forms.FloatField(label='餐品價格') picture = forms.ImageField(label=’餐品圖片’)4.html模板文件(增加菜品)

注意一定要添加:enctype=“multipart/form-data”。

<form action='updateDish_post/' method='post' enctype='multipart/form-data'> {% csrf_token %} {{form.as_p}} <button type='submit'>修改</button> <button type='button'><a href='http://www.hdgsjgj.cn/MerchantSystem/DelDish/{{dishID}}/' rel='external nofollow' >刪除</a></button></form>5.顯示菜品的html模板文件

重要的是src中路徑的配置,有兩種方法,建議法一,自己感覺比較安全,就算沒有picture時也不會報錯。(注意:可調(diào)整圖片顯示大小)

法一:/IMG(你自己定義的MEDIA_URL)/{{dish.picture}} ----dish代表后端傳來的菜品,dish.picture代表你使用的這個類中的那個有ImageField屬性的字段;

法二:{{dish.picture.url}} 因為ImageField是文件類,里面有三個屬性name、path、url可以直接訪問。

{% for dish in menu %}<!--將目錄的數(shù)據(jù)展示在html中--><!-- 提交到一個含參數(shù)的url注意后端的接收 --><form action='/MerchantSystem/Dish/{{dish.ID}}/' method='post'> {% csrf_token %} <li class='media'> <div ><img src='https://rkxy.com.cn/IMG/{{dish.picture}}' alt=''> </div> <div class='media-body'> <h4 class='media-heading'><button type=’submit’ >菜名:{{dish.itemName|default:'Null'}}</button><span class='label label-default'> 價格:{{dish.price|default:'Null'}}</span> </h4> 簡介:{{dish.itemText|default:'Null'}} </div> </li></form>{% empty %}<!--若中無數(shù)據(jù)展示如下內(nèi)容--><p>暫無數(shù)據(jù)..</p>{% endfor %} {% endblock tableBody %}6.路徑靜態(tài)化

在所有的url中都要配置如下:urlpatterns + static…

from django.conf import settingsfrom django.conf.urls.static import staticurlpatterns = [ path(’’, views.base_view, name = 'base'),# 顧客服務(wù)系統(tǒng) path(’order/<int:dishID>/’, views.order_view),# 訂單詳情 path(’order/<int:dishID>/submit/’,views.order_submit),# 提交訂單 path(’pay/<int:orderID>/’, views.pay_view),# 繳費 path(’pay/<int:orderID>/submit/’,views.pay_submit),#確認賬單 path(’order/list/’,views.order_list_view),#歷史訂單列表 path(’order/confirm/<int:orderID>/’,views.order_confirm),#訂單確認收到 path(’order/comment/<int:orderID>/’,views.comment),#到達相應(yīng)菜品的評論界面 path(’order/comment_post/<int:orderID>/’,views.comment_post)#提交評論] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)7.修改上傳的圖片

首先用form表單上傳圖片,檢查有效之后,把cleaned_data中的picture數(shù)據(jù)賦值給要更新對象中的picture屬性,最后save即可。代碼如下:

def updateDish_post(request,dishID): ''' 接受修改菜品的請求 ''' dish_form = MerchantDish(request.POST,request.FILES) if dish_form.is_valid() : dish = Menu.objects.get(ID = dishID) dish.itemName = dish_form.cleaned_data[’itemName’] dish.itemText = dish_form.cleaned_data[’itemText’] dish.price = dish_form.cleaned_data[’price’] dish.picture = dish_form.cleaned_data[’picture’] dish.save() # dishChange = dish_form.clean()return redirect(’/MerchantSystem/’) elif dish_form.errors is not None: print(dish_form.errors) return HttpResponse(str(dish_form.errors))8.設(shè)置默認圖片

這個步驟我查了好久的資料,但是都不行,好像不可以直接在model.py文件中設(shè)置default,我最后都快放棄了,但是自己還是憑運氣試出來了,不知道原理,但還是放在這,希望對大家有幫助。方法是在顯示圖片的html模板中的src處寫一個default,代碼如下:dish是后端傳過來的參數(shù),default指向的是默認圖片所在的位置。

<div ><!-- {{dish.url|default:'Null'}} --><img src='https://rkxy.com.cn/IMG/{{dish.picture|default:’img/default.jpg’}}' alt=''> </div>參考資料:

ImageField的使用

默認圖片的賦值(感覺方法不行)

到此這篇關(guān)于django中ImageField的使用詳解的文章就介紹到這了,更多相關(guān)django ImageField 內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 电销卡_稳定企业大语音卡-归属地可选-世纪通信 | 上海logo设计| 衢州装饰公司|装潢公司|办公楼装修|排屋装修|别墅装修-衢州佳盛装饰 | 江苏齐宝进出口贸易有限公司 | 浙江清风侠环保设备有限公司| 宜兴市恺瑞德环保科技有限公司 | 304不锈钢无缝管_不锈钢管厂家 - 隆达钢业集团有限公司 | 橡胶电子拉力机-塑料-微电脑电子拉力试验机厂家-江苏天源 | 10吨无线拉力计-2吨拉力计价格-上海佳宜电子科技有限公司 | 智能监控-安防监控-监控系统安装-弱电工程公司_成都万全电子 | 食品无尘净化车间,食品罐装净化车间,净化车间配套风淋室-青岛旭恒洁净技术有限公司 | 中式装修设计_全屋定制家具_实木仿古门窗花格厂家-喜迎门 | 欧必特空气能-商用空气能热水工程,空气能热水器,超低温空气源热泵生产厂家-湖南欧必特空气能公司 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 上海皓越真空设备有限公司官网-真空炉-真空热压烧结炉-sps放电等离子烧结炉 | 宁夏活性炭_防护活性炭_催化剂载体炭-宁夏恒辉活性炭有限公司 | 商标转让-商标注册-商标查询-软著专利服务平台 - 赣江万网 | 紫外荧光硫分析仪-硫含量分析仪-红外光度测定仪-泰州美旭仪器 | 工业废水处理|污水处理厂|废水治理设备工程技术公司-苏州瑞美迪 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 整合营销推广|营销网络推广公司|石家庄网站优化推广公司|智营销 好物生环保网、环保论坛 - 环保人的学习交流平台 | 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 耐磨陶瓷,耐磨陶瓷管道_厂家-淄博拓创陶瓷科技 | 空气弹簧|橡胶气囊|橡胶空气弹簧-上海松夏减震器有限公司 | 精密线材测试仪-电线电缆检测仪-苏州欣硕电子科技有限公司 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | 宁波普瑞思邻苯二甲酸盐检测仪,ROHS2.0检测设备,ROHS2.0测试仪厂家 | 浙江自考_浙江自学考试网 | 上海深蓝_缠绕机_缠膜机-上海深蓝机械装备有限公司 | 钢结构厂房造价_钢结构厂房预算_轻钢结构厂房_山东三维钢结构公司 | 动物解剖台-成蚊接触筒-标本工具箱-负压实验台-北京哲成科技有限公司 | 岩棉板|岩棉复合板|聚氨酯夹芯板|岩棉夹芯板|彩钢夹芯板-江苏恒海钢结构 | 海峰资讯 - 专注装饰公司营销型网站建设和网络营销培训 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 真空冷冻干燥机_国产冻干机_冷冻干燥机_北京四环冻干 | 武汉不干胶印刷_标签设计印刷_不干胶标签印刷厂 - 武汉不干胶标签印刷厂家 | 艾默生变频器,艾默生ct,变频器,ct驱动器,广州艾默生变频器,供水专用变频器,风机变频器,电梯变频器,艾默生变频器代理-广州市盟雄贸易有限公司官方网站-艾默生变频器应用解决方案服务商 | 飞飞影视_热门电影在线观看_影视大全 | 制丸机,小型中药制丸机,全自动制丸机价格-甘肃恒跃制药设备有限公司 | 上海佳武自动化科技有限公司| 双齿辊破碎机-大型狼牙破碎机视频-对辊破碎机价格/型号图片-金联机械设备生产厂家 | 全自动不干胶贴标机_套标机-上海今昂贴标机生产厂家 |