Kerangka Flask

Flask adalah mikro-framework yang memiliki sedikit ketergantungan pada library eksternal. Ini adalah kerangka kerja yang sangat ringan dan memberi kita kebebasan untuk melakukan apapun yang kita inginkan.

Dalam bab ini, kita akan membuat proyek menggunakan kerangka kerja Python dan Flask.

Flask Startup dan Konfigurasi

Seperti kebanyakan pustaka python yang banyak digunakan, paket Flask dapat diinstal dari Python Package Index (PPI). Mari kita buat direktori terlebih dahulu (Dalam bab ini, kita telah membuat direktori bernamaflaskProject) kemudian menciptakan lingkungan virtual (dan menyebutnya sebagai flaskEnv) di mana semua dependensi terkait proyek akan dimuat (termasuk flask). Anda juga dapat menginstal flask-sqlalchemy sehingga aplikasi flask Anda memiliki cara sederhana untuk berkomunikasi dengan database SQL.

Setelah menginstal flask, flaskEnv Anda (nama virtualEnvironment kami) akan menampilkan sesuatu seperti di bawah ini -

Membuat aplikasi dengan flask

Dengan memasang flask, kita dapat membuat "hello application in flask”Dengan sangat sedikit baris kode sebagai berikut -

Ketik yang berikut di terminal -

$python flaskapp.py

Dan Anda dapat melihat output berikut -

Berlari http://127.0.0.1:5000/ atau di localhost:5000

Di bawah ini adalah penjelasan tentang apa yang kami lakukan di kode contoh kami -

  • Pertama, kita mengimpor pustaka kelas Flask. Contoh dari kelas ini adalah aplikasi WSGI.

  • Kedua, kami membuat instance dari kelas ini. Paket aplikasi atau nama modul adalah argumen pertama kami. Flask wajib mengetahui di mana menemukan file statis, template dan file lainnya.

  • Berikutnya adalah dekorator route () yang kita gunakan untuk mengetahui URL mana yang harus memicu metode / fungsi kita.

Membuat Perutean URL

Perutean URL membuat URL di aplikasi Web Anda mudah diingat. Kami sekarang akan membuat beberapa rute URL -

/hello
/members
/members/name

Kita dapat menulis kode berikut berdasarkan URL di atas dan menyimpannya sebagai app.py.

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
   return "Index!"
	
@app.route('/Hello')
def hello():
   return "Hello, World!"
	
@app.route("/members")
def members():
   return "Members"
	
@app.route("/members/<name>/")
def getMember(name):
   return name
	
if __name__ == '__main__':
   app.run(debug=True)
Saat memulai ulang aplikasi, kami menggunakan baris kode di bawah ini untuk mendapatkan keluaran yang berbeda di berbagai URL -

$ python app.py

Running on http://localhost:5000/

Kami akan mendapatkan output berikut di browser kami -

Kami dapat mencoba URL lain di browser kami sebagai berikut -

Running on http://localhost:5000/hello, will give the following output −

Running on http://localhost:5000/members, will give −

Running on http://localhost:5000/members/TutorialsPoint/, will give you the following output −

Tetapi biasanya kami tidak ingin mengembalikan string (seperti di atas), kami mengembalikan template. Untuk itu kami ingin menggunakan fungsi “render_template”Dari flask, dan kembalikan render_template dengan beberapa masukan. Jadi, fungsi di bawah ini akan melakukan pekerjaan kita -

from flask import render_template
return render_template(‘home.html’)

Mari kita buat template folder dan tempatkan file home.html di dalamnya.

Selanjutnya kita akan membahas tentang layout. Alih-alih menggunakan tag kepala html dan tag tubuh untuk setiap templat, kami akan merancang tata letak untuk menyertakan tag head & body dan membungkus tampilan saat ini atau templat saat ini. Untuk itu, kita harus membuat satu file terpisah dan menamainyalayout.html. Dalam hal ini, kita dapat meletakkan tag kepala normal, tag tubuh, dan semua tag lain yang diperlukan.

Kita dapat membuat layout.html baru kita dengan baris kode berikut -

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>MyFlaskApp</title>
      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
   </head>
   <body>
      {% include 'includes/_navbar.html' %}
      <div class="container">
      {% block body %}
      {% endblock %}
      </div>
      <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js">
      </script>
   </body>
</html>

Pada kode di atas, kita telah memberikan judul lagu, MyFlaskAp, menggunakan css cdn di head, dan javascript di body block untuk mengaktifkan bootstrap.

Sekarang, kita harus membuat navbar untuk setiap halaman. Untuk itu, kita harus membuat folder include terlebih dahulu lalu membuat file _navbar.html di dalamnya. Sekarang di _navbar.html, kita harus menggunakan template starter standar dari getbootstrap.com. File _navbar.html yang baru dibuat adalah sebagai berikut -

Dan sertakan file _navbar.html ini ke dalam file layout.html kami.

{% include 'includes/_navbar.html' %}

Karena kami memiliki blok tata letak, kami dapat memperluas blok ini di file beranda kami (home.html).

File home.html kami dapat dibuat menggunakan kode di bawah ini -

{% extends 'layout.html' %}
{% block body %}
   <div class="jumbotron text-center">
      <h1>Welcome to FlaskApp</h1>
      <p>This application is built on Flask webframework!</p>
   </div>
{% endblock %}

Menggunakan ini jika kami mencoba menjalankan file flaskapp.py kami, maka kami dapat melihat output di bawah ini di browser kami -

Sekarang kami ingin mengaktifkan (saat ini tab tidak berfungsi) kami abouttab. Buat rute untuk tab tentang dan buat file template,about.html.

Tentang rute tab di appflask.py akan seperti yang ditunjukkan di bawah ini -

about.html file akan memiliki konten di bawah ini -

Jadi Home dan About sekarang sudah diurus. Untuk Artikel, kita dapat membuat file baru (data.py) di direktori root, tempat kita meletakkan data dan menyebutnya di halaman web kita.

data.py

def Articles():
   articles = [
      {
         'uid': 1,
         'title': 'Article_One',
         'body': 'Flask, being a microframework, often requires some repetitive step
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Rajesh Joshi',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 2,
         'title': 'Article_Two',
         'body': "Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.",
         'Author': 'Rajesh J',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 3,
         'title': 'Article_Three',
         'body': 'Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could be
            abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Joshi Rajesh',
         'Created-on': '07-09-2018'
      }
   ]
   return articles

Di bawah ini adalah kode untuk articles.html, yang akan menampilkan judul artikel untuk setiap uid.

{% extends 'layout.html' %}
{% block body %}
   <h1>Articles</h1>
   {% for article in articles %}
      <li class="list-group-item">
         <a href="article/{{article.uid}}"> {{article.title}}</a>
      </li>
   {% endfor %}
{% endblock %}

Untuk meringkas, Flask adalah salah satu framework web python paling populer karena ringan. Meskipun mikro, ini adalah kerangka kerja web python yang dapat diperluas. Dengan menyediakan fungsionalitas yang dibutuhkan, flask mempercepat pengembangan aplikasi web sederhana. Jadi Flask, lebih cocok untuk aplikasi yang lebih kecil dan tidak rumit.