我的結(jié)果
博客的框架,58二手手機轉(zhuǎn)轉(zhuǎn)信息的數(shù)據(jù)
我的代碼(過程):
這次作業(yè)有點繞
模塊介紹
思路
整體思路
### settings.py ###
from mongoengine import connect
connect('walden', host='127.0.0.1', port=27017)
### modules.py ###
from django.db import models
from mongoengine import *
class ArtiInfo(Document):
# 必須包含數(shù)據(jù)庫中的全部字段(除_id),也就說這部分少寫一個都不行
# 這里class里面name、region……什么的,
name = StringField()
region = StringField()
contact = StringField()
title = StringField()
price = StringField()
time = StringField()
# 定位數(shù)據(jù)庫中的collection
meta = {'collection':'phone_info_test'}
### views.py ###
from django.shortcuts import render
from blog.models import ArtiInfo # 調(diào)用modules中的類
from django.core.paginator import Paginator # 分頁工具 Paginator
def index(request):
limit = 4
arti_info = ArtiInfo.objects # 提取數(shù)據(jù)
paginator = Paginator(arti_info, limit) # 把提取的數(shù)據(jù)分頁,每頁4個
page = request.GET.get('page', 1) # 把request變成了一個頁碼
# 第幾頁 # 類型為list,元素為字典,每頁有幾個對象就有幾個字典(文檔)
loaded = paginator.page(page)
content = {'ArtiInfo': loaded}
return render(request, 'index.html', content)
### 分頁器 ###
<div class="main-content-pagitor">
{% if ArtiInfo.has_previous %}
<a href="?page={{ ArtiInfo.previous_page_number }}">< pre</a>
{% endif %}
<span> {{ ArtiInfo.number }} of {{ ArtiInfo.paginator.num_pages }} </span>
{% if ArtiInfo.has_next %}
<a href="?page={{ ArtiInfo.next_page_number }}">next ></a>
{% endif %}
</div>
關于Paginator
from django.core.paginator import Paginator
Paginator(迭代器, 每頁個數(shù))
分頁器
Paginator.page(1)
返回Paginator對象
Paginator.page(1).object_list
返回頁面所有數(shù)據(jù)
Paginator.page(1).has_next()
返回布林值
Paginator.page(1).number
返回int,當前第幾頁
Paginator.page(1).paginator.num_pages
返回int,共有幾頁
我的感想
寫完都還是有點暈乎乎的