The 7 Steps Here: Final Project Link
The 7 Steps Here: Final Project Link
The 7 Steps Here: Final Project Link
http://www.webdesigncourse.co/omnifood/index.php
Start off by defining the goal of your project. This can be showing your portfolio to the world, selling
an e-book, building a blog, etc.
Also define your audience. Ask yourself: which is the typical user that will visit my website?
This is important, because you should always design with your goal and audience in mind.
Once your project is defined, plan your content carefully. This includes text, images, videos, icons,
etc.
Remember what I told you about visual hierarchy. It plays an important role when you start thinking
about what you want on your website and what you don't. Defining the content before actually
starting the design is called the content-first approach. It means that you should design for the
content, instead of designing a webpage and then filling it with some stuff.
Define the site structure. You can draw a sitemap in this step if we're talking about a bigger project.
Now it's time to get inspired and think about your design.
Then, get the ideas out of your head. And with that I mean that you should sketch your ideas before
you start designing. It will help you explore ideas and create a concept of what you want to build.
Using pencil and paper is a great way of quickly retaining your valuable ideas.
Make as many sketches as you want, but don't spend too much time perfecting anything. Once you
have an initial idea, you can concentrate on the details when designing in HTML and CSS.
I advise you to never, ever start designing without having an idea of what you want to build. Getting
inspiration is very important in this phase, and I already told you how to do that!
You'll do that using HTML and CSS, which is called designing in the browser. Designing in the browser
is basically designing and developing at the same time.
There are more and more designers leaving traditional design programs such as Photoshop and start
designing in the browser. The biggest reason for this is that you can't design responsive websites in
photoshop. It also saves you tons of time.
In this phase, you'll use your sketches, content and planning decisions you've made in steps 1, 2 and
3.
Before you can actually launch your beautiful masterpiece for the world to see it, we have to
optimize its performance in terms of site speed.
You also need to do some basic search engine optimization (SEO) for search engines such as google.
All you need for launching is a webserver that will host your website and deliver it to the world.
7. Site maintenance
Now it's time to monitor your users' behavior and make some changes to your website if necessary.
You should also update your content regularly in order to show your users that your website is alive!
For instance, a blog can be a great way of doing that.
And here go all the answers
1. My code is broken and I can’t move forward in the course. What should I do?
Start by spending some time trying to solve the problem on your own. This is very important for your
learning process! To find errors, you can compare your code with the downloadable code for each
section.
If you really can’t solve the problem on your own, please post your code to a new codepen
(http://codepen.io/pen/), hit save, copy your link and start a new post in the Q&A.
Please explain your problem in a very specific way: that will guarantee you get a good answer! You
can even post a screenshot of the problem (not the code!).
It's very difficult for me to find out what's wrong with Brackets on your computer. Sometimes it's
enough to just restart Brackets or the Chrome window.
If that doesn't help, please try the official Brackets troubleshoot guide on github:
https://github.com/adobe/brackets/wiki/Troubleshooting#livedev
You can also just ignore Live Preview and open the index.html file directly.
I have actually stopped using the quick edit functionality long ago, because it never really works as
expected, so don't worry about it. You don't need to use quick edit at all. Just add the code to your
CSS stylesheet wherever you see fit.
These errors that Brackets shows you are because it expects pure JavaScript code, and not jQuery
code, as we are using here. In other words, Brackets thinks we have errors in our JavaScript code,
because it doesn't seem to understand that we're using the jQuery framework.
https://www.udemy.com/design-and-develop-a-killer-website-with-html5-and-
css3/learn/v4/questions/851800
6. My icons are not working. What can I do?
Sometimes using the icons on the local computer doesn't work very reliably. Please use the following
icons instead:
7. The background image looks different in the course, it doesn’t move. Why?
I show you how to do that effect later in the course, it appeared in one video by mistake because I
produced one after all the other videos.
But here's how you get that effect with the background image:
background-attachment: fixed;
8. My background images looks different on iOS devices than in the course. Why?
background-attachment: fixed;
doesn't work on iOS devices. What we can do in this situation is to target iOS devices using media
queries, and apply the following rule:
background-attachment: scroll;
Alternatively, you could just ignore background-attachment: fixed; altogether for smaller screen
widths. That should be easier.
You can try to highlight individual sections and prefix only those sections one by one, sometimes
that works.
Also, it only works if you have no bugs in your CSS code at all. You can check if you have some here:
https://jigsaw.w3.org/css-validator/
This problem is most likely related with lowercase and uppercase filenames. On Windows or macOS
it doesn't matter if you use lowercase and uppercase in filenames. However, on the server, which is
typically Linux, it does matter.
For example, if your file is called style.css and you include it in your HTML as Style.css, it won’t work
on the server. So please make sure that you include all your files with the exact correct filename.
11. The responsive navigation disappears after resizing the window. Why is that?
This is actually a small bug in my code. There is a post in the Q&A that shows you how to solve that
issue:
https://www.udemy.com/design-and-develop-a-killer-website-with-html5-and-
css3/learn/v4/questions/821648
12. There are some other problems going on with the navigation. How can I fix these?
I already did that for you! I coded up a new version of the responsive navigation, it fixes all the issues
there with the existing one.
Please replace all the navigation-related CSS code in your 767px media query by the one in this
fiddle:
https://jsfiddle.net/d83ykzku/1/
Please also replace the jQuery code for the navigation with the one you can find in the link above.
You can of course change the colors and style :)
Has the jQuery worked before? Are you sure you included the script.js file correctly, as well as the
jQuery library? Are you using the correct class names in both HTML and jQuery code?
Please take a look at this post in the Q&A where I solve one of the possible problems with this:
https://www.udemy.com/design-and-develop-a-killer-website-with-html5-and-
css3/learn/v4/questions/1589266
https://www.udemy.com/design-and-develop-a-killer-website-with-html5-and-
css3/learn/v4/questions/1967866
Map lecture: https://jsfiddle.net/uo3uxo1f/
Okay, that is a very good question. So, we use px and % in different situations. We use percentages
more for "layout" elements, which means elements that define the layout and that we want to
change according to the screen width. Also, percentages are most useful for defining horizontal
distances between elements, such as widths or margin-left or margin-right , not vertical distances,
because responsive web design works with screen widths (horizontal). In other words, everything
that we want to change based on the screen width when the screen becomes smaller, should be
defined in %.
Also, font-sizes are always defined in %, except for the base font-size defined for the body element,
so that we can easily change font-sizes for smaller screen sizes. More about that later in Section 6.
We use px to define some margins and paddings, and sometimes to define smaller distances and
distances that doesn't need to change when the screen changes. For the paddings, please note that
we can only use px here thanks to box-sizing: border-box; , which ensures that the box width
(defined in %) always stays the same no matter how much padding we add inside of it.
Relative positioning simply positions the elements relative to the other elements on the webpage.
Elements just appear on the website in the order they are defined in the HTML document. You can
use margins to relatively position elements, i.e. to create space between elements.
The main difference is that you can use classes as many times as you want on each website, but IDs
only once.
This can be a problem. Imagine that you use an ID for something you think you will only use once,
but later you decide you want to reuse that style. Then you'd have to go back and change from ID to
class, and you’d also have to update your CSS. That's why you should only use classes and no IDs. I
agree that this may not be the case with this exact project, but it will help you in the future.
The important issue here is code maintenance. It's easier to maintain code which has just classes and
not a mixture of classes and IDs. That's why I have chosen to never use IDs and recommend students
to do the same.
19. Why did you use the figure and ul elements for the meals section instead of just using plain
img elements? (This logic applies to all questions of this type)
Please understand that in this course I had to mix a real website with teaching things to students.
That's why in some circumstances, like having the figures just with an image and no caption, I do
things just to show you new elements or stuff like that. That's why I used the figure element. This
gives you a foundation so that you can now go ahead and add a <figcaption> to it.
As of the unordered list, this is just to make it more semantic. These images are, in fact, like a list of
meals with an image, right? And if we feel like it's a list, then we should express that with HTML,
even if it doesn't look any different in the final website. That's called semantic HTML, and it’s
important to use it.
20. What’s the difference between the body selector and the universal selector (*)?
The universal selector simply selects each and every element on the webpage and applies the styles
to all of them, unless we apply a different style somewhere else.
The body and html are different. We apply styles to the body/html elements that will be inherited by
other elements. These are most commonly styles related to text, like the font-family, font-size or
font-weight properties, because these properties get inherited by other elements. This means that
once we define them on a parent element, all of the child elements will also get these properties
automatically. And that's why we define these right on the html and body elements, because they
are the parent elements of all the other elements.
21. Why does the order in which we place the scripts matter?
Our own script.js file should always be the last one. That's because of the dependencies we have in
our code. For example, with jQuery, we use it in our script.js file., so it's a dependency. And we need
to load that dependency before we can use it, of course. And that's why the jQuery should be loaded
first. And the same of course applied to other external scripts.
The .clearfix class has the pseudo-element :after because we want to properties, especially clear:
both (which does the real work of clearing the floats) to happen at the end of the element (after) on
which we use the clearfix class. As for the other properties, there is no real explanation, this is just a
"hack", which means that it solves the problem in a strange way. This (or in a slightly different
version) is how everybody uses the clearfix.
So this course only covers HTML and CSS, which are front-end technologies, or client-based
technologies, meaning that these run in the user's browser. You use them to build the user interface
that the user sees and interacts with.
Now, a shopping cart is somewhat different, because it involves some functionality, some logic, that
needs to be programmed. We can't do that with HTML and CSS. This is called back-end
development, and it usually involves a server and database, and you need some more advanced
coding skills for it.
You can learn some more on this blog post I wrote some time ago:
http://codingheroes.io/blog/
24. What’s the difference between Bootstrap and the grid system used in the course?
The difference between Bootstrap and this small Grid System is that Bootstrap is an entire
framework including thousands of lines of HTML, CSS and JavaScript, which you can use for quickly
building a website using pre-defined building blocks. It also includes a sophisticated grid system.
Now, the Grid System we use in this course is just a small CSS file which defines the rows and
columns of our small fluid grid. If you look at the code, you'll see it's so simple that you could even
hand-code it yourself :)
I thinks it's important to learn Bootstrap as well, because it's most likely the most popular
framework in the world, but it's equally important to first fully understand the fundamentals of
HTML, CSS and responsive web design without any framework.
In my opinion, before you start creating websites using one of these tools, you should know how the
underlying technologies of web development work, and that's HTML, CSS and also JavaScript (not so
much covered in this course, but in a future course).
First, knowing the fundamental building blocks of the web allows you to create 100% custom
websites without any themes or constraints. You are not bound to a template or theme that
someone else designed. Creativity is the only limit when you really know what you're doing, and that
is very empowering.
Second, I think it's far more professional to actually know how stuff works under the surface, then
just make a website for a client using some Wordpress theme or wix template.
And third, HTML, CSS and JavaScript are used to build web applications, so if you want to do that,
you obviously will have to know them really well.
The meaning of colors in web design
Picking a color for a website means more then picking your favorite color and turning it into a
design. It means picking the right color in order to get the desired response from your audience.
Color really makes a difference. This happens because there are psychological effects behind each
color.
Red is a great color to use when power, passion, strength and excitement want to be
transmitted. Brighter tones are more energetic and darker shades are more powerful and
elegant.
Orange draws attention without being as overpowering as red. It means cheerfulness and
creativity. Orange can be associated with friendliness, confidence, and courage.
Yellow is energetic and gives the feeling of happiness and liveliness. Also, it associates with
curiosity, intelligence, brightness, etc.
Green is the color of harmony, nature, life and health. Also, it is often associated with
money. In design, green can have a balancing and harmonizing effect.
Blue means patience, peace, trustworthiness, and stability. It is one of the most beloved
colors, especially by men. It is associated with professionalism, trust and honor. That's
actually why the biggest social networks use blue.
Purple is traditionally associated with power, nobility and wealth. In your design, purple can
give a sense of wisdom, royalty, nobility, luxury, and mystery.
Brown is the color of relaxation and confidence. Brown means earthiness, nature, durability,
comfort, and reliability.
The ultimate cheatsheet: all web design guidelines in one place
This cheat sheet is intended to serve as a quick reference for you.
It contains all the guidelines I showed you in this web design section.
It is very important that you have all of the guidelines in mind at the same time when you're
making your designs.
Beautiful Typography
3. Use a line spacing between 120 and 150% of the font size
6. Chose a font which reflects the look and feel you want for your website
Most of your content will be text, so beautiful typography is a key element to a good looking
website.
Images are getting more and more important in webdesign, so choosing great images and
putting text on them is an essential part of your work.
Icons are also a good way of setting a friendly tone for your website, but use them carefully.
The adequate use of whitespace makes a website look professionally designed, so use it a
lot, but in the correct way.
Build a layout by defining the visual hierarchy of your content. Whitespace is also important
for this.
Your website should be designed in a way that ensures that both the user and the owner of
the website achieve their goals. This is the user experience.
It is very important that you get inspired by studying well-designed websites from other
designers.