cari
Rumahpembangunan bahagian belakangTutorial PythonMenyelam jauh ke dalam templat flask

Artikel ini menyediakan panduan komprehensif untuk template flask, meliputi kepentingan, faedah, dan aplikasi praktikal. Kami akan meneroka membuat dan membuat templat, menggunakan warisan dan susun atur templat, bekerja dengan pembolehubah dan struktur kawalan, borang pengendalian dan input pengguna, menggunakan penapis terbina dalam dan tersuai, menguruskan fail statik dan media, dan melaksanakan teknik template maju. Sama ada anda pemula atau pemaju flask yang berpengalaman, penerokaan yang mendalam ini akan meningkatkan pemahaman dan kemahiran anda dalam membina antara muka web yang dinamik dan visual. (Nota: pemahaman asas kelalang diandaikan.)

A Deep Dive into Flask Templates

Mengapa menggunakan templat flask?

Templat flask adalah penting untuk kod yang berstruktur, boleh dipelihara, dan boleh diguna semula. Dengan memisahkan persembahan (UI) dari logik aplikasi, mereka memudahkan kemas kini UI tanpa mengubah kod backend. Pemisahan ini meningkatkan kerjasama antara pemaju dan pereka. Faedah utama termasuk:

  • kebolehbasa semula kod: Buat komponen yang boleh diguna semula (tajuk, footer, navigasi) untuk UI yang konsisten di beberapa halaman.
  • Pembacaan yang lebih baik: Pemisahan bersih kod HTML dan Python meningkatkan pemahaman dan pemeliharaan.
  • kemudahan penyelenggaraan: kemas kini logik atau templat secara bebas tanpa menjejaskan yang lain.
  • fleksibiliti: mudah lulus data ke dan dari templat untuk penjanaan kandungan dinamik.

membuat dan membuat template

Templat flask tinggal di direktori

dalam direktori akar aplikasi anda. Flask menggunakan enjin templat Jinja2, menyokong pelbagai sambungan (templates, .html, .svg, dan lain -lain). Kami akan memberi tumpuan kepada .csv. .html

Contoh Struktur Aplikasi:

<code>my_app/
├── app.py
└── templates/
    └── index.html</code>
template

mudah: index.html

<!DOCTYPE html>
<html>
<head>
  <title>Index</title>
</head>
<body>
  <h1 id="Welcome">Welcome</h1>
  <p>This is the index page.</p>
</body>
</html>
rendering dengan fungsi

Flask: render_template()

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
  return render_template('index.html')

if __name__ == '__main__':
  app.run()

warisan dan susun atur template

Pewarisan Jinja2 membolehkan membuat template asas dengan unsur -unsur biasa (header, footer, navigasi) dan memperluaskannya dalam templat kanak -kanak.

Template Base (): base.html

<!DOCTYPE html>
<html>
<head>
  <title>{% block title %}{% endblock %}</title>
</head>
<body>
  <nav></nav>
  <div class="content">
    {% block content %}{% endblock %}
  </div>
</body>
</html>

template kanak -kanak (): home.html

{% extends 'base.html' %}

{% block title %}Home - My Website{% endblock %}

{% block content %}
  <h1 id="Welcome-to-My-Website">Welcome to My Website</h1>
  <p>This is the home page content.</p>
{% endblock %}

pembolehubah templat dan struktur kawalan

Lulus data dari flask ke templat menggunakan argumen kata kunci

atau kamus konteks. Pembolehubah akses dalam templat menggunakan render_template(). {{ variable_name }}

Pembolehubah lulus:

return render_template('template.html', name="Alice", age=30)

Menggunakan pembolehubah dalam : template.html

<code>my_app/
├── app.py
└── templates/
    └── index.html</code>

Struktur kawalan (jika/lain, untuk gelung):

<!DOCTYPE html>
<html>
<head>
  <title>Index</title>
</head>
<body>
  <h1 id="Welcome">Welcome</h1>
  <p>This is the index page.</p>
</body>
</html>

konteks templat dan pembolehubah global

Konteks templat mengandungi pembolehubah yang tersedia untuk templat. Flask menyediakan request, session, config, url_for(), dan g (untuk pembolehubah global). Gunakan g untuk berkongsi data merentasi permintaan:

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
  return render_template('index.html')

if __name__ == '__main__':
  app.run()

Borang Templat dan Input Pengguna

Gunakan borang HTML atau perpustakaan WTForms untuk pengendalian bentuk yang mantap. WTForms menyediakan pengesahan dan memudahkan penciptaan bentuk.

Penapis terbina dalam dan tersuai

Jinja2 menawarkan penapis terbina dalam (mis.,

, upper, lower). Buat penapis tersuai untuk melanjutkan fungsi: capitalize

<!DOCTYPE html>
<html>
<head>
  <title>{% block title %}{% endblock %}</title>
</head>
<body>
  <nav></nav>
  <div class="content">
    {% block content %}{% endblock %}
  </div>
</body>
</html>

Bekerja dengan fail statik dan media

Simpan fail statik (CSS, JS, imej) dalam direktori

. Gunakan static untuk menjana URL untuk fail ini dalam templat. url_for('static', filename='...')

Teknik Templat Lanjutan Kemasukan template

    ():
  • menggunakan semula komponen biasa. {% include 'partial.html' %} macros (
  • ):
  • Buat blok kod yang boleh diguna semula dalam templat. {% macro my_macro(arg) %}{% endmacro %} ujian templat dan debugging:
  • Gunakan tag
  • (untuk pembangunan) dan ujian menyeluruh untuk mengenal pasti dan memperbaiki isu -isu. {% debug %}
  • Kesimpulan

Menguasai templat flask adalah kunci untuk membina aplikasi web yang mantap dan boleh dipelihara. Dengan menggunakan teknik yang dibincangkan secara berkesan, anda boleh membuat antara muka web dinamik, mesra pengguna, dan visual yang menarik. Ingatlah untuk berunding dengan dokumentasi Flask dan Jinja2 untuk butiran lanjut dan ciri -ciri canggih.

Atas ialah kandungan terperinci Menyelam jauh ke dalam templat flask. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Menyenaraikan senarai di Python: Memilih kaedah yang betulMenyenaraikan senarai di Python: Memilih kaedah yang betulMay 14, 2025 am 12:11 AM

Tomergelistsinpython, operator youCanusethe, extendmethod, listcomprehension, oritertools.chain, eachwithspecificadvantages: 1) operatorSimpleButlessefficientficorlargelists;

Bagaimana untuk menggabungkan dua senarai dalam Python 3?Bagaimana untuk menggabungkan dua senarai dalam Python 3?May 14, 2025 am 12:09 AM

Dalam Python 3, dua senarai boleh disambungkan melalui pelbagai kaedah: 1) Pengendali penggunaan, yang sesuai untuk senarai kecil, tetapi tidak cekap untuk senarai besar; 2) Gunakan kaedah Extend, yang sesuai untuk senarai besar, dengan kecekapan memori yang tinggi, tetapi akan mengubah suai senarai asal; 3) menggunakan * pengendali, yang sesuai untuk menggabungkan pelbagai senarai, tanpa mengubah suai senarai asal; 4) Gunakan itertools.chain, yang sesuai untuk set data yang besar, dengan kecekapan memori yang tinggi.

Rentetan senarai concatenate pythonRentetan senarai concatenate pythonMay 14, 2025 am 12:08 AM

Menggunakan kaedah Join () adalah cara yang paling berkesan untuk menyambungkan rentetan dari senarai di Python. 1) Gunakan kaedah Join () untuk menjadi cekap dan mudah dibaca. 2) Kitaran menggunakan pengendali tidak cekap untuk senarai besar. 3) Gabungan pemahaman senarai dan menyertai () sesuai untuk senario yang memerlukan penukaran. 4) Kaedah mengurangkan () sesuai untuk jenis pengurangan lain, tetapi tidak cekap untuk penyambungan rentetan. Kalimat lengkap berakhir.

Pelaksanaan Python, apa itu?Pelaksanaan Python, apa itu?May 14, 2025 am 12:06 AM

PythonexecutionistheprocessoftransformingpythoncodeIntoExecutableInstructions.1) TheinterpreterreadsTheCode, convertingIntoByteCode, yang mana -mana

Python: Apakah ciri -ciri utamaPython: Apakah ciri -ciri utamaMay 14, 2025 am 12:02 AM

Ciri -ciri utama Python termasuk: 1. Sintaks adalah ringkas dan mudah difahami, sesuai untuk pemula; 2. Sistem jenis dinamik, meningkatkan kelajuan pembangunan; 3. Perpustakaan standard yang kaya, menyokong pelbagai tugas; 4. Komuniti dan ekosistem yang kuat, memberikan sokongan yang luas; 5. Tafsiran, sesuai untuk skrip dan prototaip cepat; 6. Sokongan multi-paradigma, sesuai untuk pelbagai gaya pengaturcaraan.

Python: pengkompil atau penterjemah?Python: pengkompil atau penterjemah?May 13, 2025 am 12:10 AM

Python adalah bahasa yang ditafsirkan, tetapi ia juga termasuk proses penyusunan. 1) Kod python pertama kali disusun ke dalam bytecode. 2) Bytecode ditafsirkan dan dilaksanakan oleh mesin maya Python. 3) Mekanisme hibrid ini menjadikan python fleksibel dan cekap, tetapi tidak secepat bahasa yang disusun sepenuhnya.

Python untuk gelung vs semasa gelung: Bila menggunakan yang mana?Python untuk gelung vs semasa gelung: Bila menggunakan yang mana?May 13, 2025 am 12:07 AM

UseAforLoopWheniteratingOvereForforpecificNumbimes; Useaphileloopwhencontinuinguntilaconditionismet.forloopsareidealforknownownsequences, sementara yang tidak digunakan.

Gelung Python: Kesalahan yang paling biasaGelung Python: Kesalahan yang paling biasaMay 13, 2025 am 12:07 AM

Pythonloopscanleadtoerrorslikeinfiniteloops, pengubahsuaianListsduringiteration, off-by-oneerrors, sifar-indexingissues, andnestedloopinefficies.toavoidthese: 1) use'i

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Nordhold: Sistem Fusion, dijelaskan
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan