Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Home Page | FrontEnd Design
Flask Intensive Course: Web Development with Python

book
Home Page

Our Home page looks like that.

Let's beef it up a little bit. Under the different navbar examples, we can see this nice gray rectangle with a little bit of text and a little button here to launch something. Put this into our Home Page with some welcome things and some little things to explain what it is, and then have this link to our main web page with all our recipes.

Let's go back to the View Page Source code here. Find <h1>Navbar examples</h1> at the end of the page.

html

index

css

index

js

index

copy
<div>
<div class="bg-body-tertiaryp-5 rounded">
<div class="col-sm-8 mx-auto">
<h1>Navbar examples</h1>
<p>This example is a quick exercise to illustrate how the navbar and its contents work. Some navbars extend the width of the viewport, others are confined within a <code>.container</code>. For positioning of navbars, checkout the <a href="/docs/5.3/examples/navbar-static/">top</a> and <a href="/docs/5.3/examples/navbar-fixed/">fixed top</a> examples.</p>
<p>At the smallest breakpoint, the collapse plugin is used to hide the links and show a menu button to toggle the collapsed content.</p>
<p>
<a class="btn btn-primary" href="/docs/5.3/components/navbar/" role="button">View navbar docs &raquo;</a>
</p>
</div>
</div>
</div>

So our Home page is empty. Go to the index.html, which is our template for Home page. Right below that Home page text, paste in the key elements and give the whole document a little style.

Once that's done, hit the refresh button, and voilà! Your page just got a whole lot more interesting.

Instead of Nawbar examples, let's write "Welcome to CookBook Craze" and change the text here on the welcome text generated by ChatGPT.

html

index

css

index

js

index

copy
<div>
<div class="bg-body-tertiaryp-5 rounded">
<div class="col-sm-8 mx-auto">
<h1>Welcome to CookBook Craze</h1>
<p>Discover the joy of cooking, one recipe at a time. Whether you're a seasoned chef or just starting your culinary journey, you've found your online haven for all things delicious.</p>
<p>Start your culinary exploration now, and let the Cookbook Craze community inspire your next gastronomic masterpiece. Welcome to a world where every meal is a masterpiece waiting to be created.</p>
<p>
<a class="btn btn-primary" href="/recipes/" role="button">Go to recipes &raquo;</a>
</p>
</div>
</div>
</div>

Let's make things more interactive. How about counting the number of recipes in our database and displaying that count on the Home page? To do this, we'll need to insert a new tag between the paragraph and a button like this: <h3>We have {{ }} recipes</h3>.

Now, head over to the main.py file, and within the home function, create a variable with a query to retrieve the recipe count from the database. Then, pass this variable as a parameter when rendering the template.

@app.route("/")
@app.route("/home/")
def home():
num_recipes = Recipe.query.count()
return render_template("index.html", num_recipes=num_recipes)

Come back to the index.html and add inside curly braces {{ num_recipes }}.

Refresh page:

So, we've got a navbar up and running, and we've created a beautiful Home page – all thanks to Bootstrap, which worked quite swiftly. With some inspect-copy-paste-edit techniques, you can easily incorporate any free design from the internet.

Tudo estava claro?

Como podemos melhorá-lo?

Obrigado pelo seu feedback!

Seção 4. Capítulo 3
some-alt