再我登陸計入主頁後,主頁的資料是用form表單接收的嗎?查到的數(shù)據(jù)不知道怎麼放到頁面上,有沒有什麼資料推薦一下,或是給點指導(dǎo)
走同樣的路,發(fā)現(xiàn)不同的人生
我想把從資料庫查到的資料顯示到頁面上,我想知道是不是用form提交上去的?找不到參考資料
我將根據(jù)這句話來回答樓主的問題。
我先概括一下思路:用路由把SQLAlchemy查詢到的資料透過參數(shù)傳遞給render_template函數(shù),再在.html檔中用jinja2實作動態(tài)渲染網(wǎng)頁。
例如現(xiàn)在你有一個部落格資料庫,你需要把部落格的內(nèi)容顯示到主頁上,該如何顯示呢?
主要的方法其實是用jinja2
來實現(xiàn),首先假設(shè)你有一個Post
數(shù)據(jù)庫(已經(jīng)在models.py
中定義好了的,別跟我說你不懂! ! )
好吧你不懂,就像這樣:
from . import db
class Post(db.Model):
__tablename__ = 'posts'
id = db.Column(db.Integer, primary_key=True)
body = db.Column(db.Text)
body_html = db.Column(db.Text)
timestamp = db.Column(db.DateTime, index=True, default=datetime.utcnow)
author_id = db.Column(db.Integer, db.ForeignKey('users.id'))
comments = db.relationship('Comment', backref='post', lazy='dynamic')
db.event.listen(Post.body, 'set', Post.on_changed_body)
什麼你不懂db是哪裡import來的?是app包裡__init__.py
來的呀!這裡懶得解釋了,直接貼文完整的init方法吧
from flask import Flask
from flask_bootstrap import Bootstrap
from flask_mail import Mail
from flask_moment import Moment
from flask_sqlalchemy import SQLAlchemy
from flask_login import LoginManager
from flask_pagedown import PageDown
from config import config
bootstrap = Bootstrap()
mail = Mail()
moment = Moment()
db = SQLAlchemy()
pagedown = PageDown()
login_manager = LoginManager()
login_manager.session_protection = 'strong'
login_manager.login_view = 'auth.login'
def create_app(config_name):
app = Flask(__name__)
app.config.from_object(config[config_name])
config[config_name].init_app(app)
bootstrap.init_app(app)
mail.init_app(app)
moment.init_app(app)
db.init_app(app)
login_manager.init_app(app)
pagedown.init_app(app)
if not app.debug and not app.testing and not app.config['SSL_DISABLE']:
from flask_sslify import SSLify
sslify = SSLify(app)
from .main import main as main_blueprint
app.register_blueprint(main_blueprint)
from .auth import auth as auth_blueprint
app.register_blueprint(auth_blueprint, url_prefix='/auth')
from .api_1_0 import api as api_1_0_blueprint
app.register_blueprint(api_1_0_blueprint, url_prefix='/api/v1.0')
return app
不過更改資料庫記得先運行python manager.py shell來遷移一下資料庫呀(具體的自己查去)
扯遠了,我們來看樓主的問題。
首先來看路由(就是views.py
)中的內(nèi)容:
@main.route('/', methods=['GET', 'POST'])
def index():
#前面已經(jīng)假設(shè)了你有個Post數(shù)據(jù)庫
query = Post.query
#這里使用了pagination,就是自動實現(xiàn)翻頁的一個擴展,可用可不用哈
pagination = query.order_by(Post.timestamp.desc()).paginate(
page, per_page=current_app.config['FLASKY_POSTS_PER_PAGE'],
error_out=False)
#這里才是重點,簡單來說就是讓posts=Post.query.order_by(Post.timestamp.desc())
posts = pagination.items
#然后用render_template傳給html,交給jinja2來動態(tài)渲染
return render_template('index.html', form=form, posts=posts,
show_followed=show_followed, pagination=pagination)
現(xiàn)在讓我們到index.html
中來看看jinja2
該如何運作,不過為了讓index.html
看起來盡量簡潔,我將印製Post的模組單獨提了出來,叫_post.html
,在index.html
中使用只要{% include '_posts.html' %}即可:
index.html
中來看看jinja2
該如何工作,不過為了讓index.html
看上去盡量簡潔,我將打印Post的模塊單獨提了出來,叫_post.html
,在index.html
中使用只要{% include '_posts.html' %}
即可:
讓我們來看_post.html
讓我們來看_post.html
<ul class="posts">
<!--處理從路由傳進來的posts,用一個for循環(huán)處理,語法酷似python-->
{% for post in posts %}
<li class="post">
<p class="post-thumbnail">
<a href="{{ url_for('.user', username=post.author.username) }}">
<img class="img-rounded profile-thumbnail" src="{{ post.author.gravatar(size=40) }}">
</a>
</p>
<p class="post-content">
<!--Post數(shù)據(jù)在這里顯示,你要的答案就在這了。核心思想就是用jinja2 -->
<p class="post-date">{{ moment(post.timestamp).fromNow() }}</p>
<p class="post-author"><a href="{{ url_for('.user', username=post.author.username) }}">{{ post.author.username }}</a></p>
<p class="post-body">
{% if post.body_html %}
{{ post.body_html | safe }}
{% else %}
{{ post.body }}
{% endif %}
</p>
</p>
</li>
{% endfor %}
</ul>
以前看過一點《Flask Web開發(fā):基於Python的Web應(yīng)用開發(fā)實戰(zhàn)》,今天小小複習(xí)一下,如果有什麼不對的地方,請大家指出,謝謝!
樓主要的答案這本書裡都有,也強烈推薦想學(xué)flask的同學(xué)看看這本書呀!
例如你造訪的是/index頁面,你一定會有一個後端,一個前端
給你提供思路,你自己去找相關(guān)資料,搜尋引擎搜尋flask開發(fā)
@app.route('/index')
def index():
data = "從數(shù)據(jù)庫讀取出來的數(shù)據(jù)"
html = []
for item in data:
html.append(item."列名")
return ''.join(html)
你接受參數(shù),可以用路由裡面的變量,也可以用request.args.get指令來取得參數(shù)。然後執(zhí)行程式得到結(jié)果,當(dāng)然最簡單的就是拼接成字串直接用return,當(dāng)然更正式的是用render_template ,配合jinjia2渲染模板輸出。
這個還是看下flask的快速入門吧。 http://docs.jinkan.org/docs/f...