Preface
First of all, FCC is great, thanks for such a great community, contributors, and people help people to code.
For great people are about starting or just finished the FCC Survey Form Challenge, I would like to share my thoughts and idea about one great form you would start coding and bring it to real world.
As I reviewed some random Survey Form works by people submitted them on FCC forum, I found some common issues belong to most of them, so I decided to start posting this article and point them out here.
NOTE: Please have your own design(colour scheme, icons, font, ...) This document talks about issues which would break your layout. Thanks.
Table Of Content
Common Mistakes
Most common issues are about mobile layout. Almost most of the works are great on desktop view, but it's broken in mobile. Please check following items are about all common mistakes breaks a page layout in mobile.
Absolute Units
Using CSS absolute units like pixel for controlling the elements advance(width and height) would break your layout.
Issue
When specifying an absolute size for an element, it tells the browser always set the specified size to the element, the issue comes when there is not enough space, then scroll happens!
<input type="text" style="width:255px"/>
Example(bad approach): width/height control with size attribute
<input type="text" size="31"/>
Solution
Not only one fix, let check some of them.
Fix 0: Using relative units
Using relative over absolute units could ensure you you will take sizes/values (relatively)based on device screen size. For the input one good replacement for the pixel could be percent.
<form>
<!--will never overflow of its parent(form) bound-->
<input style="width:80%" type="text"/>
</form>
Beside percent % unit, you may use another relative units like view width vw too, but remember they are not the same, check following note.
Container element example:
<!--top/root layer container-->
<body>
<!--container element, vw works here-->
<form style="width:80vw">
<!--child(non-container) element, vw doesn't works here-->
<!--80% of parent width, not screen-->
<input style="width:80%"/>
</form>
</body>
Fix 1: Using relative units for default size, and absolute unit for max-size
width:90% might work very good and as expected in mobile, because in mobile we try to utilize all screen area.
For serving one css rule for one element (no @media queries), you may set the default size using a relative unit, and control the maximum size(probably for desktop view) with a absolute unit. Considering following example
.myform{
width:90vw;/*by default goes for 90% of screen width*/
max-width:10in;/*when screen is too wide, keep it 10in as max*/
}
Mixed padding and margin
One mistake beginners would take is about mixing up(mess!) padding and margin attributes for elements, especially containers.
FACT: padding of parent element, works like margin for children elements have edge-edge relation.
NOTE: browsers apply small about of margin to body tag by default, if you add a
<!--body has default margin of 8px-->
<body>
<!--the actual width is 100% + 8px +8px, so scroll-->
<div style="width:100%">
</div>
</body>
Issue
Using relative units for padding/margin, and using absolute units for
<!--possible scroll when 50px+50px is more than 30% of the screen-->
<div style="padding:50px;width:70%">
</div>
Solution
This could be great to use relative units for specifying padding and margin attributes.
TIP: Use
Now check out what happens when you use
<!--body has default margin of 8px-->
<body>
<!--margin values won't be used for calculating the target advance now-->
<div style="width:100%; box-sizing:border-box">
</div>
</body>
Issue
Using negative
This is not recommended! please don't do this. Instead of applying negative value for
Example(bad approach): using negative
See the Pen Negative value for padding/margin (please don't) by NULL_dev (@NULL_dev11) on CodePen.
Solution
Fix is easy, but remember if you code in proper way, you will never face with sucha situation to think about using negative
For above bad example case(code snipped 8), as you see browser applies some padding(not really padding, but like padding, it's for sample) for
See the Pen ZRywgo by NULL_dev (@NULL_dev11) on CodePen.
Element Spacing
In mobile, this is good practice to bring more space between elements(especially the input elements)
The reason is simple, pointing with finger is hard, but it's easy with mouse
Issue
Not enough spacing between elements, make it hard to select element in mobile, also make it harder to read and scan page content.
FACT: Default spacing setting by browsers are good enough for desktop and big screens, but for mobile this might be better to bring some more spacing.
Please considering following example comes with zero spacing between elements. This may not critical for desktop, but for mobile is kind of a little hard to tap on exact element.
Example(bad design): Not enough spacing between elements could make it hard to select them. Same make it hard to read page content.
See the Pen not enough spacing between input elements by NULL_dev (@NULL_dev11) on CodePen.
Solution
For mobile view, adding spacing between elements(especially input elements), a little more
NOTE: Small elements on either small or large screens are no recommended. Enlarging small elements, or providing easy access to them would help too much.
Considering following example which comes with a layout with good spacing between elements, and some padding for text fields and text areas.
See the Pen yEPvem by NULL_dev (@NULL_dev11) on CodePen.
label For input Tags
Each
One good
In mobile view especially, as tapping on a small radio button could be a little hard, tapping on label to to select the radio/checkbox is much easier and good thing.
Issue
It's a common issue developers forget to associate a
Considering following bad example, that radio and checkbox element comes without any associated label. user needs to click/tap on radio/checkbox circle/square element to select the element. The text next to radio doesn't forward tap/click event to radio/checkbox.
Example(bad approach):
See the Pen KeXMoZ by NULL_dev (@NULL_dev11) on CodePen.
Solution
So simple to associate a
Fix 0: host the input element within a label tag.
This is one very easy solution, simply put the
Now considering following example. As
See the Pen ERwgaq by NULL_dev (@NULL_dev11) on CodePen.
TIP: You may not just put text inside a
Considering following example, that clicking in any colour are causes the radio select becasue is part of the
See the Pen Lrzmgb by NULL_dev (@NULL_dev11) on CodePen.
PRO TIP: You would simply hide the radio button, and with some help of js(very easy), perform some kind of fancy radio button rendering.
Even you not clicking on radio button, and it's hidden, but you actually sent the event, and the related parameter is set, so it's completely html compatible.
I note I've never done this before, but it was full of fun, so easy! YES. Considering following example.
See the Pen Cool customized radio button by NULL_dev (@NULL_dev11) on CodePen.
Fix 1: linking label to input element using for="input_id" attribute
This way needs one more step over fix0 solution. And it's really easy, each
Now
NOTE: You may not host the
TIP: not only one
Considering following example
See the Pen oyGYod by NULL_dev (@NULL_dev11) on CodePen.
Not enough contrast between background and foreground colours
Issue
Not having enough contrast between foreground(fg) and background(bg) colours, make it hard to read content of page. Example using very light colours on white.
This is really easy to find out if your page is not very readable, and contains this issue. Simply try to read content(text, objects...) of your page, or even better ask a friend.
If it looks a little hard, or after a while of reading you have some pain on your eyez, so you've got some problems. Considering following example
Example(bad design): Usine not enough contrast or sync-ed values between fg and bg colours.
See the Pen Not sync-ed fg and bg background colour by NULL_dev (@NULL_dev11) on CodePen.
Solution
Since this is related to design, and out of standard sort of. So no one can tell what colour is good for bg, and what should be used for fg?
Again, just make sure your content of page are very clear for reading, at any part.
Personally I go for white for bg, black for fg, and two colours(usually lime, and cyan) for primary and secondary colours. Those primary and secondary colours are used for elements need dedicated attention, such as form submit buttons, or hyperlinks(anchors), etc... Considering following example
See the Pen Sample page 0 by NULL_dev (@NULL_dev11) on CodePen.
Placeholders for text fields and text areas
Placeholder is a default text is used/rendered about text fields, and text areas when they are empty.
Issue
Text fields and text areas come without any placeholder associated. Instead they have some default
Considering following bad example uses wrong way bring placeholder like approach using default
Example(bad approach): Using default
See the Pen don't use default values as placeholders by NULL_dev (@NULL_dev11) on CodePen.
Solution
Both
See the Pen using palceholder for textfield and textarea by NULL_dev (@NULL_dev11) on CodePen.
NOTE: do not use placeholder for specifying a default value, instead set the
NOTE: Placing anything(including white space, new line, ... anything) between open and close
Suggestions
Now time for some suggestion. Please note these are not law of the work, but I think having them could make work better. You may simply ignore them all.
Mark(Split) Form's Sections Using Horizontal (hr tag)
Having horizontal line between sections of form make it more easier to read. user would find it easier if some some parts are belong to each other. In some cases this section splitter is kind of essential, but for survey form this could be there(better), or not.
For instance your very first section of form could be the text fields you take name, email and age of the user. After these elements, you may put a horizontal line.
Another example could be about group of checkbox buttons. As you asking some yes/no questions, these could be assume one section, so horizontal lines before and after checkbox buttons.
I also suggest you don't let the horizontal line reach any visible vertical(left and right)border too. It will makes your design a little weird! let it be 75% of width for example.
Don't Override Global font-size
Many users (including me), set desired font-size with their browser. I set 18px as default(someone set as 10px, and someone set as 32px). But when a page sets global font-size to 14px, it is me to zoom and just ignores applied size.
The bad part is you applied some layout based on font-size you set, so zooming would breaks page layout.
FACT: best global font-size is no any global font-size.
NOTE: Since now you don't know what is a default global font-size, so using pixel(or any absolute) unit to enlarge a section is not a good idea at all! Usr
No any valid default option for combobox(select )
By default, the very first element of
Solution 0(recommended): using a disabled option as default element.
For some situation, selecting a valid option as default works, but sometimes you need user attention to select the correct value. And the problem is when a valid value is selected, user may forget to select the correct value and submit the form.
For combobox, this is a good practice to have a disabled(non selectable) option with a informative label such as "--please select--" and mark it as default selected. And as it's disabled, user may not select it again.
Considering following example.
See the Pen Using a disabled option for select element as default value by NULL_dev (@NULL_dev11) on CodePen.
Solution 1: Using a hidden option and mark it as selected or palce it at first
So easy, just considering exmaple.
See the Pen Using a hidden option to set nothing as default value for select by NULL_dev (@NULL_dev11) on CodePen.
Solution 2: Get some help of JS, to set nothing as selected index(element)
In js, you would access the
Setting the selected element(
See the Pen Using js to set default(nothing) element for select by NULL_dev (@NULL_dev11) on CodePen.
Design Suggestion
Beside suggestions for all about layouting, let's have some small suggestion about the design.
NOTE: You may ignore this section, since it reflects some personal(opinion-based) ideas about the designing. Thanks.
Sharp And Perfect-Size Form
Having a background colour for page(usually lighter colour of primary colour), and primary background colour(probably white) for form makes the design kind of nice.
Having a form which elements are all fit to screen width in desktop view looks not so logical, while it's better to make it fit for small devices and avoid having not necessary styling stuffs like too much
Hopefully this is really easy to control the maximum width form using
But for mobile, as I stated, this may be good to use spaces for page content, and remove some styling needs space like
This is also so easy to get some help of media queries to hide/remove some styling and bring more space for content.
NOTE AGAIN: In mobile layouting, space is gold. A good layout utilise the maximum space of screen, while it provide good spacing between elements too.
Considering the primary background is lime, bg is white, fg is black, now putting all above stuffs together, considering following example.
See the Pen Sharp and perfect-size form by NULL_dev (@NULL_dev11) on CodePen.
A sharp and contrasted submit button is the best
This may be not so logical, but works indeed, to place the submit button center of form, make it sharp(bold 'n' big) and contrasted.
Just as I suggested about having a primary contrasted colour(usually not grayscale), using the primary colour as background color for submit button works very good.
For instance please refer to code snippet 18., or previous sample.
Same Advance For Comboboxes, Text Fields, And Text Areas
Your form may place text fields(comboboxes, and text areas) in same x position in your page, so as they starts from one position, they could be better to end with one position too.
This makes Your form look more pro I think, but again my opinion, you may reject.
Template Layout
Here I would share some very basic layout template you may use to bring your survey page based on them.
Sample Responsive Layout
Now we would have one, very simple layout without any media queries, working perfectly for any screen.
Feel free to use and give feedback to make it better, remember it is here becasue of simplicity, not expecting to bring some fancy stuffs like bootstrap, etc...
See the Pen Sample Responsive Layout by NULL_dev (@NULL_dev11) on CodePen.
Responsive Grid(2 col) Layout Template
Before we talk about two column table like grid layout, I think one column layout(or flow layout) works well for almost every page for all devices.
NOTE: since we are talking about survey form, for desktop and wide enough screens(probably tablets too) we would go for a two-column layout too.
But it doesn't matter if I like or not, let's have a responsive two column grid template layout which turns into one column
Fix 0: using repeat as grid template column
This approach is my favorite, it's simple, and easy.
Using
IMPORTANT NOTE: Using
Again, remember to set correct values for grid container width size, same the columns width to let it be 1 column(when screen is small) or 2 when screen is wide enough.
Please considering following example. Try to open the codepen link and resize the preview/result pane to see how does grid response to different sizes. Also check and see how grid container width is sync with column template repeat value to avoid 3rd and next columns.
See the Pen Sample grid 2-col responsive layout by NULL_dev (@NULL_dev11) on CodePen.
Simple you could host
NOTE: please note you still need some hand of media queries to center text when design is in 1 column form(mobile) or at left when desktop.
Fix 1: using some help of media queries to bring great layout for different screen sizes
This approach is one very common way to get some hand of media queries controlling layout for different screen sizes.
It gives more control over fix 0 solution, as you could override almost everything.
Considering following example is kind of same as above, but using media queries and more better styling
See the Pen WyXWdM by NULL_dev (@NULL_dev11) on CodePen.
Sampel Survey Form
Now let's have all of the stuff we talked about, and have a simple(yes simple. because simple works all the time, but to be honest I'm not very good at designing :D) survey page. YES.
NOTE: I'm not a UI/UX expert, but I always try my best about it. The design may not look okay. I just focused on layout to bring it functional and right. Thanks.
NOTE: This sample survey form does not follow FCC rules and would be failed by FCC tests. This is just for sampling, not a FCC survey form template. Thanks.
See the Pen sample survey form by NULL_dev (@NULL_dev11) on CodePen.
META
Dear great friend, thanks for reading. If you think some part of the article needs editing, or any missed subject could be there, feel free to comment and share your thoughts. Thanks.
HAPPY PROGRAMMING!
No comments:
Post a Comment