데이터베이스에서 검색된 데이터를 페이지에 표시하고 싶습니다. 양식을 사용하여 제출되었는지 알고 싶습니다. 참조를 찾을 수 없습니다
원문 포스터의 질문에 이 문장을 바탕으로 답변해 드리겠습니다.
먼저 아이디어를 요약하겠습니다. 라우팅을 사용하여 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)
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
现在让我们到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' %만 있으면 됩니다. }그렇습니다. _post.html를 살펴보겠습니다🎜
으아아아
🎜전에 "Flask 웹 개발: Python을 기반으로 한 실용적인 웹 애플리케이션 개발"을 조금 읽었습니다. 오늘은 조금 검토해 보고 잘못된 점이 있으면 지적해 주세요. 🎜
🎜저자의 답변이 이 책에 모두 담겨있습니다. 플라스크를 배우고 싶은 학생들은 이 책을 꼭 읽어보시길 추천드립니다! 🎜
매개변수를 수락하거나, 경로에 변수를 사용하거나, request.args.get 명령을 사용하여 매개변수를 가져올 수 있습니다. 그런 다음 프로그램을 실행하여 결과를 얻습니다. 물론 가장 간단한 방법은 이를 문자열로 연결하고 직접 return을 사용하는 것입니다. 물론 더 공식적인 방법은 render_template을 사용하고 jinjia2와 협력하여 템플릿 출력을 렌더링하는 것입니다.
Flask의 빠른 시작을 살펴보겠습니다. http://docs.jinkan.org/docs/f...
원문 포스터의 질문에 이 문장을 바탕으로 답변해 드리겠습니다.
먼저 아이디어를 요약하겠습니다. 라우팅을 사용하여 SQLAlchemy에서 쿼리한 데이터를 매개 변수를 통해 render_template 함수에 전달한 다음 .html 파일에서 jinja2를 사용하여 웹 페이지를 동적으로 렌더링합니다.
예를 들어, 이제 블로그 데이터베이스가 있고 이를 홈페이지에 표시하려면 어떻게 해야 할까요?
주요 방법은 실제로
jinja2
를 사용하여 구현하는 것입니다. 먼저Post
데이터베이스(이미models.py
에 정의되어 있음)가 있다고 가정합니다. , 이해하지 못한다고 말하지 마세요 )jinja2
来实现,首先假设你有一个Post
数据库(已经在models.py
中定义好了的,别跟我说你不懂!!)好吧你不懂,就像这样:
什么你不懂db是哪里import来的?是app包里
__init__.py
来的呀!这里懒得解释了,直接帖个完整的init方法吧不过更改数据库记得先运行python manager.py shell来迁移一下数据库呀(具体的自己查去)
扯远了,我们来看楼主的问题。
首先来看路由(就是
views.py
)中的内容:现在让我们到
당신은 이해하지 못하겠지만, 다음과 같습니다: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' %만 있으면 됩니다. }그렇습니다.
_post.html
를 살펴보겠습니다🎜 으아아아 🎜전에 "Flask 웹 개발: Python을 기반으로 한 실용적인 웹 애플리케이션 개발"을 조금 읽었습니다. 오늘은 조금 검토해 보고 잘못된 점이 있으면 지적해 주세요. 🎜 🎜저자의 답변이 이 책에 모두 담겨있습니다. 플라스크를 배우고 싶은 학생들은 이 책을 꼭 읽어보시길 추천드립니다! 🎜예를 들어 /index 페이지를 방문하면 백엔드와 프론트엔드
으아악가 있어 직접 관련 정보를 찾을 수 있고 검색 엔진을 사용하여 플라스크 개발을 검색할 수 있습니다
매개변수를 수락하거나, 경로에 변수를 사용하거나, request.args.get 명령을 사용하여 매개변수를 가져올 수 있습니다. 그런 다음 프로그램을 실행하여 결과를 얻습니다. 물론 가장 간단한 방법은 이를 문자열로 연결하고 직접 return을 사용하는 것입니다. 물론 더 공식적인 방법은 render_template을 사용하고 jinjia2와 협력하여 템플릿 출력을 렌더링하는 것입니다.
Flask의 빠른 시작을 살펴보겠습니다. http://docs.jinkan.org/docs/f...