建立一个图书列表页面,显示图书名列表,并实现点击书名跳转到图书详细页面,显示图书详细信息。
- URL方法简介
- 功能:返回一个绝对路径的引用(不包含域名的URL);该引用匹配一个给定的视图函数和
一些可选的参数。 - 语法:
{% url ‘some-url-name‘ value1 value2 %}
- 参数‘some-url-name‘表示在urls.py文件中的路由地址;
- 参数value1和value2表示拼接的值,可选。
- 例如,urls.py:
url(r‘^bookinfo/(\d+)/$‘, polls_views.bookinfo, name=‘book‘)
html代码中:{% url ‘book‘ 3 %}
;
拼接后返回地址为:bookinfo/3/
数据库djangodemo中存有信息:
表polls_book
+----+--------------+-----------+
| id | name | person_id |
+----+--------------+-----------+
| 1 | 围城 | 1 |
| 2 | 蝴蝶梦 | 2 |
| 3 | 鲁滨逊漂流记 | 3 |
| 4 | 小王子 | 4 |
+----+--------------+-----------+
表polls_person
+----+------+-----+
| id | name | age |
+----+------+-----+
| 1 | Joe | 12 |
| 2 | walt | 18 |
| 3 | walt | 17 |
| 4 | Jany | 20 |
| 5 | John | 29 |
+----+------+-----+
- 先写出图书列表页面
- 实现超链接自动拼接
- 编写图书详情页面
# 导入路由,支持正则表达式from django.conf.urls import url# 在路由匹配模式中添加图书列表页面的路由urlpatterns = [ ???url(r‘^booklist/$‘, polls_views.booklist), # 定义拼接地址,获取书籍信息 ???url(r‘^bookinfo/(\d+)/$‘, polls_views.bookinfo, name=‘bookinfo‘)]
# 图书列表页面控制器def booklist(request): ???# 导入图书类 ???from polls.models import Book ???# 实例化一个图书对象 ???books = Book.objects.all() ???# 建立空字典存储booklist ???dict_book = {} ???dict_book[‘booklist‘] = books ???# 向bookList.html页面传入数据dict_book ???return render(request, ‘bookList.html‘, dict_book)
- 2. 在templates文件夹下新建bookList.html文件,并添加
{# 在bookList.html文件的body下添加如下代码 #}<body> ???<h2>图书架</h2> ???<ul> ???????{% for book in booklist %} ???????????{# 使用每本书的book.id作为获取详情的查询条件,生成链接 #} ???????????<li><a href="{% url ‘bookinfo‘ ?book.id ?%}">{{ book.name }}</a></li> ???????{% endfor %} ???</ul></body>
- 3. 在view.py文件中定义获取书籍信息详细信息的控制方法
# 获取书籍信息def bookinfo(request, id): ???# 导入图书类 ???from polls.models import Book ???# 实例化一个图书对象,使用book.id查询该书籍数据 ???book = Book.objects.get(id=id) ???# 建立空字典存储booklist ???dict_book = {} ???# 存储book书名 ???dict_book[‘book‘] = book.name ???# 存储book作者 ???dict_book[‘author‘] = book.person.name ???# 存储book作者年龄 ???dict_book[‘author_age‘] = book.person.age ???# 向bookInfo.html页面传入数据dict_book ???return render(request, ‘bookInfo.html‘, dict_book)
- 4. 在templates文件夹下新建bookInfo.html文件,并添加
{# 在bookInfo.html文件的body下添加如下代码 #}<body> ???<h2>{{ book }}</h2> ???<ul> ???????<li>作者:{{ author }}</li> ???????<li>年龄:{{ author_age }}</li> ???</ul></body>
- 在浏览器中访问http://127.0.0.1:8000/booklist/
可以看出,地址栏里的127.0.0.1:8000/bookInfo/3中"3"是根据书籍“鲁滨逊漂流记”的id获取的,“鲁滨逊漂流记”在数据库表polls_book中对应的id是3。
表polls_book
+----+--------------+-----------+
| id | name | person_id |
+----+--------------+-----------+
| 1 | 围城 | 1 |
| 2 | 蝴蝶梦 | 2 |
| 3 | 鲁滨逊漂流记 | 3 |
| 4 | 小王子 | 4 |
+----+--------------+-----------+
- 以上工作的条件是你已经完成了Django的正常配置,并正常开启了server;
- 数据库中的数据是预先添加好的,这里只是查询数据库中的数据。
- 能力有限,欢迎指错纠正。