小編給大家分享一下django之html模板中如何調(diào)用對(duì)象屬性或?qū)ο螅嘈糯蟛糠秩硕歼€不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
環(huán)境:依賴最初test2數(shù)據(jù)庫(kù)
python3版本
多python版本環(huán)境
進(jìn)入,python3虛擬環(huán)境,新建項(xiàng)目test4:
]# cd py3/django-test1/
]# django-admin startproject test4
創(chuàng)建應(yīng)用bookshop:
]# cd test4
]# python manage.py startapp bookshop
修改settings.py主配置文件:
]# vim test4/settings.py
...
#數(shù)據(jù)庫(kù)為mysql,使用原來(lái)的test2數(shù)據(jù)庫(kù)名稱:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'test2',
'USER': 'root',
'PASSWORD': 'root',
'HOST': '192.168.255.70',
'PORT': '3306',
}
}
#添加應(yīng)用:
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'bookshop',
)
#添加模板查找路徑:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR,'templates')],
...
]
...
在項(xiàng)目名稱目錄下,添加模板目錄并在其下添加應(yīng)用的模板目錄:
]# mkdir -p templates/bookshop
在主url路由配置文件中,添加查找應(yīng)用url的路由:
]# vim test4/settings.py
...
urlpatterns = [
url(r'^admin/', include(admin.site.urls)),
url(r'^',include('bookshop.urls',namespace='bookshop')),
]
在應(yīng)用目錄下創(chuàng)建urls.py文件:
]# vim bookshop/urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'\^$',views.index,name='index'),
]
以上基本配置完成,下面演示在模板中調(diào)用對(duì)象的方法:
定義模型類:
為了不用遷移,定義模型類要和test2數(shù)據(jù)庫(kù)結(jié)構(gòu)一樣;
]# vim bookshop/models.py
from django.db import models
class BookInfo(models.Model):
btitle = models.CharField(max_length=20)
bpub_date = models.DateTimeField(db_column='pub_date') #定義字段名稱為pub_date,默認(rèn)字段名稱就是類屬性,即默認(rèn)字段名稱為bpub_date
bread = models.IntegerField()
bcommet = models.IntegerField()
isDelete = models.BooleanField()
#定義表名
class Meta():
db_table = 'bookinfo'
#如果不寫(xiě)上面2行,表名默認(rèn)為項(xiàng)目名稱.類名稱,即bookshop.bookinfo
class HeroInfo(models.Model):
hname = models.CharField(max_length=10)
hgender = models.BooleanField()
hcontent = models.CharField(max_length=1000)
isDelete = models.BooleanField()
book = models.ForeignKey('BookInfo') #定義外鍵,此處引號(hào)是否可省略,BookInfo先定義就可省略引號(hào),如果后定義則需要使用引號(hào),使用引號(hào)絕對(duì)沒(méi)錯(cuò);在表中字段自動(dòng)變?yōu)閎ook_id
def showname(self):
return self.hname
定義視圖:
]# vim bookshop/views.py
from django.shortcuts import render
from .models import *
#from models import * #在python2寫(xiě)法
def index(request): #必須接收一個(gè)參數(shù)
hero = HeroInfo.objects.get(pk=1) #查詢主鍵(pk)=1的條目
context = {'hero':hero} #必須為字典格式
return render(request,'bookshop/index.html',context)
定義index.html模板文件:
]# vim templates/bookshop/index.html
<!DOCTYPE html>
<html>
<head>
<title>Title</title>
</head>
<body>
{{ hero.hname }}<br><!--調(diào)用對(duì)象的屬性-->
{{hero.showname}}<!--調(diào)用對(duì)象的方法,但不能給方法傳遞參數(shù)-->
<!--注釋
#點(diǎn)號(hào)解析順序:
#1.先把hero作為字典,hname為鍵查找
#2.再把hero作為對(duì)象,hname為屬性或方法查找
#3.最后把hero作為列表,hname為索引查找
-->
</body>
</html>
啟動(dòng)web服務(wù):
]# python manage.py runserver 192.168.255.70:8000
報(bào)錯(cuò):Error loading MySQLdb module: No module named 'MySQLdb'
解決:由于在python3版本上使用pymysql庫(kù),沒(méi)有MySQLdb庫(kù),則需要配置;
]# vim test4/__init__.py
import pymysql
pymysql.install_as_MySQLdb()
再次啟動(dòng)web服務(wù)成功;瀏覽器訪問(wèn):http://192.168.255.70:8000/
django之html模板中如何調(diào)用對(duì)象屬性或?qū)ο?創(chuàng)新互聯(lián)
瀏覽路徑:http://vcdvsql.cn/article24/pjeje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、網(wǎng)站營(yíng)銷、虛擬主機(jī)、App開(kāi)發(fā)、服務(wù)器托管、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(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)容