data:image/s3,"s3://crabby-images/e14c7/e14c764e3c26955dc7bcef232937abbe936282a4" alt=""
目標
- Flaskのルーティングを利用した小規模アプリを作成できる。
ルーティングの利用
ルーティングの利用
Part.3までに作成したminiappアプリに「商品管理ページ」「商品追加ページ」を作成して、次のページ遷移を実装します。但し、ここでもデータベースの利用は行わず、Jinja2を利用した表示部分とそれぞれのページに関わるルーティング部分の作成のみを行います。
- 商品管理ページと商品一覧ページは双方向へ遷移可能。
- 商品管理ページと商品追加ページは双方向へ遷移可能。
- 商品一覧ページと商品追加ページは双方向へ遷移可能。
- 商品追加を行った後は商品一覧ページへリダイレクトされる。
data:image/s3,"s3://crabby-images/a2569/a25690a336d13a5a326aa39bf7bd9a13c3d780d6" alt=""
テンプレートファイルの作成
必要なテンプレートを準備します。テンプレート名は次の通りです。テンプレートファイルは「templates」ディレクトリに配置します。
- 商品管理ページ…manage_products.html
- 商品追加ページ…add_product.html
それぞれの記述内容は次の通りです。
manage_products.html
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>商品管理</title>
<link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}">
</head>
<body>
<h1>商品管理ページ</h1>
<ul>
<li><a href="{{ url_for('product_list') }}" class="button-link">商品一覧</a></li>
<li><a href="{{ url_for('add_product') }}" class="button-link">商品追加</a></li>
</ul>
</body>
</html>
add_product.html
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>商品追加</title>
<link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}">
</head>
<body>
<h1>商品追加ページ</h1>
<ul>
<li><a href="{{ url_for('product_list') }}" class="button-link">商品一覧に戻る</a></li>
<li><a href="{{ url_for('manage_products') }}" class="button-link">商品管理ページ</a></li>
</ul>
<h1>商品追加フォーム</h1>
<form method="POST" action="{{ url_for('add_product') }}">
<label for="name">商品名</label>
<input type="text" id="name" name="name" placeholder="商品名を入力" required>
<label for="price">価格</label>
<input type="number" id="price" name="price" placeholder="価格を入力" required>
<input type="submit" value="商品を追加する">
</form>
</body>
</html>
products.htmlを次のように編集します。
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>商品一覧</title>
<link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}">
</head>
<body>
<h1>商品一覧ページ</h1>
<ul>
<li><a href="{{ url_for('add_product') }}" class="button-link">商品を追加する</a></li>
<li><a href="{{ url_for('manage_products') }}" class="button-link">商品管理ページ</a></li>
</ul>
<h1>商品一覧</h1>
<ul>
{% for product in products %}
<li>{{ product.name }} : ¥{{ "{:,}".format(product.price) }}</li>
{% endfor %}
</ul>
</body>
</html>
style.cssを次のように編集します。
body {
font-family: Arial, sans-serif;
margin: 20px;
padding: 20px;
background-color: #f8f8f8;
}
h1 {
color: #333;
}
/* ボタン部分のリストを横並びにする */
ul {
padding: 0;
}
ul:first-of-type {
display: flex;
/* 横並び */
justify-content: flex-start;
/* 左寄せ */
}
ul:first-of-type li {
margin-right: 10px;
/* ボタン間に余白 */
}
/* リストアイテムの基本スタイル */
li {
list-style-type: none;
/* デフォルトのリストスタイルを削除 */
}
/* ボタンリンクのスタイル */
.button-link {
display: block;
padding: 10px 20px;
background-color: #4CAF50;
color: white;
text-decoration: none;
border-radius: 5px;
font-size: 16px;
transition: background-color 0.3s ease;
}
/* ボタンにホバーしたときのスタイル */
.button-link:hover {
background-color: #45a049;
}
/* 商品リストのスタイル */
h2 {
margin-top: 30px;
/* 商品リストの見出しに余白 */
}
ul:nth-of-type(2) {
list-style-type: none;
/* 商品リストのマーカーを削除 */
padding: 0;
}
ul:nth-of-type(2) li {
background-color: #fff;
padding: 10px;
margin: 5px 0;
border-radius: 5px;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
/* フォーム全体のスタイル */
form {
background-color: #fff;
padding: 20px;
border-radius: 5px;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
margin-top: 30px;
}
/* フォーム内のラベルのスタイル */
form label {
font-size: 16px;
color: #333;
display: block;
margin-bottom: 8px;
}
/* フォーム内の入力フィールドのスタイル */
form input[type="text"],
form input[type="number"],
form input[type="submit"] {
width: 100%;
padding: 10px;
margin-bottom: 15px;
border: 1px solid #ddd;
border-radius: 5px;
font-size: 16px;
box-sizing: border-box;
/* パディングを含めてサイズ調整 */
}
/* フォーム内のボタン(送信ボタン) */
form input[type="submit"] {
background-color: #4CAF50;
color: white;
cursor: pointer;
transition: background-color 0.3s ease;
}
/* 送信ボタンにホバーしたときのスタイル */
form input[type="submit"]:hover,
form button:hover {
background-color: #45a049;
}
ルーティングの作成(app.pyの編集)
app.pyファイルを次のように編集します。
from flask import Flask, redirect, render_template, request, url_for
app = Flask(__name__)
# 商品リスト
products = [
{"id": 1, "name": "オレンジジュース", "price": 140},
{"id": 2, "name": "アップルジュース", "price": 150},
{"id": 3, "name": "牛乳", "price": 180},
]
@app.route("/")
def index():
return "Top page"
@app.route("/products")
def product_list():
return render_template("products.html", products=products)
@app.route("/add_product", methods=["GET", "POST"])
def add_product():
if request.method == "POST":
# フォームから送られたデータを取得
name = request.form["name"]
price = int(request.form["price"])
# 新しい商品を追加
new_id = len(products) + 1
products.append({"id": new_id, "name": name, "price": price})
# 商品一覧ページにリダイレクト
return redirect(url_for("product_list"))
return render_template("add_product.html")
@app.route("/manage_products")
def manage_products():
# 商品管理ページを表示
return render_template("manage_products.html")
if __name__ == "__main__":
app.run(debug=True)
ファイルの作成、修正後は、エクスプローラで次のように表示されます。
data:image/s3,"s3://crabby-images/4ac21/4ac21e040c38c7d5b314a169e2df4384bdac4bc4" alt=""
作業が完了したら、稼働して動きを確認します。
アプリケーションの起動
環境変数を有効化して「flask run」コマンドを実行します。
C:\Users\user\Desktop\FlaskProj>.venv\Scripts\activate
# 仮想環境が有効化されます。
(venv) C:\Users\user\Desktop\FlaskProj>flask run
ブラウザで http://127.0.0.1:5000/manage_productsにアクセスします。
商品管理ページが表示されます。
data:image/s3,"s3://crabby-images/6ab13/6ab13f95ebe28e3bba796dd35019354fc4f22f6d" alt=""
商品一覧ボタンを押下すると、商品一覧ページが表示されます。
data:image/s3,"s3://crabby-images/bc5c8/bc5c85359a4b029e112675639d102a177ad2dc53" alt=""
商品を追加するボタンを押下すると、商品追加ページが表示されます。
data:image/s3,"s3://crabby-images/17178/171788ebb48fdac28729bb4dff7db278554b8e4a" alt=""
商品名と価格を入力して「商品を追加する」ボタンを押下します。
data:image/s3,"s3://crabby-images/d3163/d3163be9b8769e6bd8639c68edc08f82dde8aa7b" alt=""
http://127.0.0.1:5000/products にリダイレクトされます。
data:image/s3,"s3://crabby-images/e148b/e148b2bae57be94d2d256b8ca8992f70b6b55ad6" alt=""
商品が追加されています。
今回は以上になります。
ここでは、入力フォームの作成、複数ルーティングの設定、リダイレクトの設定を行っています。次回以降の記事で、これらについて確認します。
data:image/s3,"s3://crabby-images/e1092/e1092a0757fb87af6af10516ee4d9deb047c5814" alt=""
ブックマークのすすめ
「ほわほわぶろぐ」を常に検索するのが面倒だという方はブックマークをお勧めします。ブックマークの設定は別記事にて掲載しています。
data:image/s3,"s3://crabby-images/ebc46/ebc46d147e3ed549260db63b54f30704fae025e6" alt=""
data:image/s3,"s3://crabby-images/6ab7a/6ab7ad95ccc004d821123644f99bf0a712a92ed7" alt=""