上期文章css
下面基於上面文章的django項目中blog模塊,針對文章(article)作自定義crud頁面html
在項目根目錄新建目錄templates,用來存放頁面html文件 python
打開settings.py文件中,修改模板的配置:mysql
TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [os.path.join(BASE_DIR, "templates")], #修改 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ]
暫時註釋crsf驗證,否則會報錯:csrf token驗證失敗(後面解決csrf問題)jquery
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', #'django.middleware.csrf.CsrfViewMiddleware', #註釋 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ]
在 項目根目錄/blog/view.py
中添加list方法git
from django.shortcuts import render from . import models def list(req): data = {} #返回給頁面的數據 list = models.Article.objects.all() #從mysql查詢全部 data['list']=list return render(req, 'blog/list.html', data) #跳轉到頁面
在templates目錄新建blog目錄,在blog目錄下再新建list.htmlsql
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>博客列表</title> <!-- Bootstrap 相關文件 --> <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css"> <script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script> <script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script> </head> <body> <ul class="breadcrumb"> <li><a href="/">Home</a></li> <li><a href="#">2018</a></li> <li class="active">十一月</li> </ul> <table class="table"> <caption>文章列表</caption> <thead> <tr> <th>ID</th> <th>標題</th> <th>內容</th> <th>做者</th> <th>時間</th> </tr> </thead> <tbody> {% for d in list %} <tr> <td>{{ d.id }}</td> <td>{{ d.title }}</td> <td> {% if d.content|length > 30 %} {{ d.content|slice:'30' }}... {% else %} {{ d.content }} {% endif %} </td> <td>{{ d.author }}</td> <td>{{ d.time }}</td> </tr> {% endfor %} </tbody> </table> </body> </html>
在 根目錄/主目錄/urls.py
添加blog的路由django
from django.urls import path, include from django.conf.urls import url urlpatterns = [ path('admin/', admin.site.urls), url(r'^blog/', include('blog.urls')) #將blog路由到另外一個文件的路由配置 ]
在 根目錄/blog
中添加urls.pybootstrap
from django.conf.urls import url from . import views urlpatterns=[ url(r'^list/$',views.list), #list路由到views.list方法,作業務處理 ]
啓動項目,瀏覽器訪問 http://localhost:8000/blog/list 瀏覽器
同理,省略...
效果: