 Implement Create Functionality
Implement Create Functionality
We will add a form for adding new recipes, sending them to our database, and automatically appearing on our website page.
# main.py(continue)
@app.route("/recipes/", methods=["GET", "POST"]) 
def recipes():
    all_recipes = Recipe.query.all()
    return render_template('recipes.html', recipes=all_recipes)
GET is the method by default, and now we allow the POST one.
Now, we go to the FrontEnd template and add this form to the file recipes.html. In the body block:
The file's name in the example below doesn't correspond to the file's name in our project.
recipes.html
We've made a few enhancements to our layout. To create a horizontal line for a neater appearance, we used the <hr> tag. Next, we implemented the form with the help of the <form> tag, which is quite straightforward. To add line breaks at the end of lines, we utilized the <br> tag.
Now, let's reload our browser page to see the form in action. However, please note that you shouldn't attempt to save anything just yet; we still need to implement the POST functionality in the 'recipes' function.
We need to add some changes to our recipes function.
@app.route("/recipes/", methods=["GET", "POST"]) 
def recipes():
	if request.method == "POST":
		recipe_title = request.form["title"]
		recipe_description = request.form["description"]
		new_recipe = Recipe(title=recipe_title, description=recipe_description, author="Joey")
		db.session.add(new_recipe)
		db.session.commit()
		return redirect("/recipes/") 
	else:
		all_recipes = Recipe.query.order_by(Recipe.date_posted).all() 
		return render_template("recipes.html", recipes=all_recipes)
- if we click the 'Post' button, we activate the POST method. We get the title and description from our form and then use it to create a new database entry.
- else, we will GET all entries from our database table and print it out.
And don't forget the import redirect. We need to change dummy data onto the database. You can delete our list where we imitate our database.
You can see that our BackEnd and FrontEnd are working.
Merci pour vos commentaires !
Demandez à l'IA
Demandez à l'IA
Posez n'importe quelle question ou essayez l'une des questions suggérées pour commencer notre discussion
Awesome!
Completion rate improved to 3.85 Implement Create Functionality
Implement Create Functionality
Glissez pour afficher le menu
We will add a form for adding new recipes, sending them to our database, and automatically appearing on our website page.
# main.py(continue)
@app.route("/recipes/", methods=["GET", "POST"]) 
def recipes():
    all_recipes = Recipe.query.all()
    return render_template('recipes.html', recipes=all_recipes)
GET is the method by default, and now we allow the POST one.
Now, we go to the FrontEnd template and add this form to the file recipes.html. In the body block:
The file's name in the example below doesn't correspond to the file's name in our project.
recipes.html
We've made a few enhancements to our layout. To create a horizontal line for a neater appearance, we used the <hr> tag. Next, we implemented the form with the help of the <form> tag, which is quite straightforward. To add line breaks at the end of lines, we utilized the <br> tag.
Now, let's reload our browser page to see the form in action. However, please note that you shouldn't attempt to save anything just yet; we still need to implement the POST functionality in the 'recipes' function.
We need to add some changes to our recipes function.
@app.route("/recipes/", methods=["GET", "POST"]) 
def recipes():
	if request.method == "POST":
		recipe_title = request.form["title"]
		recipe_description = request.form["description"]
		new_recipe = Recipe(title=recipe_title, description=recipe_description, author="Joey")
		db.session.add(new_recipe)
		db.session.commit()
		return redirect("/recipes/") 
	else:
		all_recipes = Recipe.query.order_by(Recipe.date_posted).all() 
		return render_template("recipes.html", recipes=all_recipes)
- if we click the 'Post' button, we activate the POST method. We get the title and description from our form and then use it to create a new database entry.
- else, we will GET all entries from our database table and print it out.
And don't forget the import redirect. We need to change dummy data onto the database. You can delete our list where we imitate our database.
You can see that our BackEnd and FrontEnd are working.
Merci pour vos commentaires !