로그인 후 메인페이지에 포함된 후, 메인페이지의 데이터를 양식으로 받아볼 수 있나요? 찾은 데이터를 페이지에 어떻게 넣는지 모르겠어요. 추천해주실 만한 정보나 안내가 있나요?
大家讲道理2017-05-18 11:01:39
데이터베이스에서 검색된 데이터를 페이지에 표시하고 싶습니다. 양식을 사용하여 제출되었는지 알고 싶습니다. 참조를 찾을 수 없습니다
원문 포스터의 질문에 이 문장을 바탕으로 답변해 드리겠습니다.
먼저 아이디어를 요약하겠습니다. 라우팅을 사용하여 SQLAlchemy에서 쿼리한 데이터를 매개 변수를 통해 render_template 함수에 전달한 다음 .html 파일에서 jinja2를 사용하여 웹 페이지를 동적으로 렌더링합니다.
예를 들어, 이제 블로그 데이터베이스가 있고 이를 홈페이지에 표시하려면 어떻게 해야 할까요?
주요 방법은 실제로 jinja2
를 사용하여 구현하는 것입니다. 먼저 Post
데이터베이스(이미 models.py
에 정의되어 있음)가 있다고 가정합니다. , 이해하지 못한다고 말하지 마세요 )jinja2
来实现,首先假设你有一个Post
数据库(已经在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
)中的内容:
@main.route('/', methods=['GET', 'POST'])
def index():
#前面已经假设了你有个Post数据库
query = Post.query
#这里使用了pagination,就是自动实现翻页的一个扩展,可用可不用哈
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来动态渲染
return render_template('index.html', form=form, posts=posts,
show_followed=show_followed, pagination=pagination)
现在让我们到index.html
中来看看jinja2
该如何工作,不过为了让index.html
看上去尽量简洁,我将打印Post的模块单独提了出来,叫_post.html
,在index.html
中使用只要{% include '_posts.html' %}
即可:
让我们来看_post.html
으아아아
DB 가져오기가 어디서 오는지 왜 이해하지 못하시나요? 앱 패키지의__init__.py
에서 제공됩니다! 여기서 설명하기엔 너무 귀찮아서 그냥 전체 init 메소드를 포스팅하겠습니다으아아아
하지만 데이터베이스를 변경하기 전에 먼저 python Manager.py 쉘을 실행하여 데이터베이스를 마이그레이션해야 한다는 점을 기억하세요(자세한 내용은 직접 확인하세요)views.py
)를 살펴보겠습니다. 🎜
으아아아
🎜이제 index.html
로 이동하여 jinja2
가 어떻게 작동하는지 살펴보겠습니다. 하지만 index.html
을 최대한 단순하게 보이도록 하기 위해 Post를 인쇄하기 위한 모듈은 별도로 제안되어 있으며 _post.html
이라고 합니다. index.html
에서 사용하려면 {% include '_posts.html' %만 있으면 됩니다. }< /code>그렇습니다.
_post.html
를 살펴보겠습니다🎜
으아아아
🎜전에 "Flask 웹 개발: Python을 기반으로 한 실용적인 웹 애플리케이션 개발"을 조금 읽었습니다. 오늘은 조금 검토해 보고 잘못된 점이 있으면 지적해 주세요. 🎜
🎜저자의 답변이 이 책에 모두 담겨있습니다. 플라스크를 배우고 싶은 학생들은 이 책을 꼭 읽어보시길 추천드립니다! 🎜회신하다0
PHP中文网2017-05-18 11:01:39
예를 들어 /index 페이지를 방문하면 백엔드와 프론트엔드
가 있어 직접 관련 정보를 찾을 수 있고 검색 엔진을 사용하여 플라스크 개발을 검색할 수 있습니다
为情所困2017-05-18 11:01:39
매개변수를 수락하거나, 경로에 변수를 사용하거나, request.args.get 명령을 사용하여 매개변수를 가져올 수 있습니다. 그런 다음 프로그램을 실행하여 결과를 얻습니다. 물론 가장 간단한 방법은 이를 문자열로 연결하고 직접 return을 사용하는 것입니다. 물론 더 공식적인 방법은 render_template을 사용하고 jinjia2와 협력하여 템플릿 출력을 렌더링하는 것입니다.
Flask의 빠른 시작을 살펴보겠습니다. http://docs.jinkan.org/docs/f...