CSS for Form Elements
Build to separate the document content (murk-up language) from document presentation, CSS has evolved within time and now there is nothing on the web that isn’t possible with it from present different styles according to the screen resolution, for print to animations, gradient backgrounds and a lot more. CSS has changed the way the web was being designed.
Use of CSS in form elements other than the submit button & text is not common, designers still use images & CSS to style form elements, when it can be achieved with CSS alone. Styling with CSS reduces the page load and bandwidth consumption as well. In this article we will style the following form elements using CSS properties:
- Text area.
- Text fields.
- Submit buttons.
- Check boxes.
- Radio buttons.
- Select boxes.
- File upload buttons.
We will be using CSS Selectors to do the magic, if you don’t have a good hand on it, you can check out the article on CSS Selectors or CSS3 Mega Cheat Sheet
Before we get to style the elements according to our needs we must have the default styles added by the browser removed. most browsers add a few pixels of margin & padding by default and some properties to the text, therefore it’s necessary to have them eliminated.
input, select, textarea {
margin:0;
padding:0;
font-family:Arial;
-moz-box-sizing:border-box; /* Firefox */
-webkit-box-sizing:border-box; /* Safari */
box-sizing:border-box;
}
The box-sizing
will let us have padding and border for & other elements that cut into its 100% width instead of expanding it.
Text Fields & Text area
From left input & textarea without Style , followed by Styled and in focus.
Styling these elements is a very common and most designer use these to get some good look for the form, but just in case you don’t, here’s the code.
HTML
CSS
input, textarea {
width:12em;
border-radius:2px;
border: solid 1px #ccc;
padding:0.4em;
background-color: #f5f5f5;
box-shadow: inset 0 2px 3px rgba(0,0,0,0.2);
}
textarea {
width:100%;
height:10em;
}
Making textarea
larger than the other text inputs will give the user a straight idea about the field and also lets them see what they have typed, at least 5 lines will do fine. As far as usability considered it’s necessary to let the user know the difference between the input he is focusing on with the rest.
input:focus, textarea:focus {
border-color:#e8e07f;
}
HTML5 Elements
The new text attributes in HTML5 form elements like email, tel, etc can be styled like normal input fields; using CSS3 attributes selectors though you cannot style HTML5 date and number.
input[type="email"],
input[type="tel"] {
.
.
}
Buttons
For form buttons like submit
, reset
it is essential to make them eye catching and push-able in order to increase revenue on an e-commerce website.
From left buttons without style , followed by styled and the states hover & focus.
Styling them is just like styling the HTML5 Form elements using the CSS3 attributes selector. If you are in need of few other buttons other than reset & submit, you can have a class with same set of CSS property.
HTML
Button
CSS
input[type="submit"], input[type="reset"] {
border: solid 1px #ccc;
padding:0.4em 0.7em;
color:white;
-webkit-border-radius: 5px;
-moz-border-radius: 5px;
-ms-border-radius: 5px;
-o-border-radius: 5px;
border-radius: 5px;
/*To make the state change a little real*/
-webkit-transition: background-color 200ms linear; /*Safari and Chrome*/
-moz-transition: background-color 200ms linear; /*Firefox*/
-o-transition: background-color 200ms linear; /*opera*/
-ms-transition: background-color 200ms linear;
transition: all 200ms linear;
background-color: #16a6b6;
cursor: pointer;
text-align: center;
}
input[type="submit"]:hover, input[type="reset"]:hover , .button:hover{
background:#ee6557;
}
input[type="submit"]:active, input[type="reset"]:active, .button:active{
background:rgba(255,51,0,1);
}
As mentioned above in the input box styling, letting users know when they focus on an element will improve its usability, in this case we have 2 events hover
& active
states.
All the fields mentioned above were compact-able with most browsers, the form elements that are being discussed from now on need a Webkit supported browser, at present Google Chrome and Apple Safari supports it, Mozilla is expected to support it with the next release until then the Mozilla & other users will see traditional style.
Please note: the following only works as intended in browsers that support webkit properties.
Select List
From left Select List with out style, styled List right.
After styling some fields without using a single image it’s time to get complex, but still we will not be using any image as it’s.
Styling the drop down button isn’t possible so the tweak is to hide the button using -webkit-appearance
and replace it with a custom arrow in the background image. Since we don’t want to use the image as it is, we will use a 64base image.
select {
background-image: url('') ;
background-repeat:no-repeat;
background-position:right;
-webkit-appearance: none /* this is required for Webkit browsers */;
-moz-appearance: none /* this is not supported currently */;
appearance: none;
background-color:#e6e6e5;
min-width:12em;
box-shadow: 2px 1px 2px 1px rgba(0,0,0,0.1);
border: solid 1px #ccc;
border-radius:5px;
}
Check Boxes and Radio Buttons
File Input is another HTML5 form element, styling is similar to styling Select List, We will hide the default appearance of the element using -webkit-appearance
and replace it with the new styles.
HTML
Like the Select List drop down button, the Check Boxes & Radio buttons cannot be styled, but have the tweak, hide the button using -webkit-appearance
and override.
CSS (Check Boxes)
input[type="checkbox"] {
-webkit-appearance: none;
border: 1px solid #cacece;
box-shadow: 0 1px 2px rgba(0,0,0,0.05), inset 0 -15px 10px -12px rgba(0,0,0,0.05);
display: inline-block;
position: relative;
top: 3px;
margin: 0 10px;
padding: 8px;
}
input[type="checkbox"]:checked{
background-color: #fff;
border: 1px solid #ccc;
box-shadow: 0 1px 2px rgba(0,0,0,0.05), inset 0 -15px 10px -12px rgba(0,0,0,0.05), inset 15px 10px -12px rgba(255,255,255,0.1), inset 0 0 10px rgba(0,0,0,0.1);
background-position:center;
background-image: url();
}
From left Check Boxes & Radio Buttons with out style , styled and check .
Just to prevent things from getting a mess, the CSS for Check Box & Radio buttons has been split.
CSS (Radio Buttons)
input[type="radio"] {
-webkit-appearance: none;
border: 1px solid #cacece;
box-shadow: 0 1px 2px rgba(0,0,0,0.05), inset 0 -15px 10px -12px rgba(0,0,0,0.05);
display: inline-block;
position: relative;
top: 3px;
margin: 0 10px;
padding: 8px;
-webkit-border-radius: 20px;
-moz-border-radius: 20px;
-ms-border-radius: 20px;
-o-border-radius: 20px;
border-radius: 20px;
}
input[type="radio"]:checked{
background-color: #ededed;
border: 1px solid #ccc;
box-shadow: 0 1px 2px rgba(0,0,0,0.05), inset 0 -15px 10px -12px rgba(0,0,0,0.05), inset 15px 10px -12px rgba(255,255,255,0.1), inset 0 0 10px rgba(0,0,0,0.1);
}
File Input
File Input is another HTML5 form element, styling is again similar to styling a standard input, using the CSS3 attributes selector to get the magic done.
From left File input with out style and the one with styles in right.
HTML
In here the only thing possible is to change the look of the choose file button, although it’s possible to change the entire element using images, but in order to stay with the policy of no image the “choose file” button is the only available option. The -webkit-file-upload-button
selector rocks..!.
CSS
input[type="file"] {
margin:0 0 0 0.5em;
}
input[type=file]::-webkit-file-upload-button {
background-color: #f5f5f5;
box-shadow: inset 0 2px 3px rgba(0,0,0,0.2);
border: solid 1px #ccc;
-webkit-appearance: none;
box-shadow: 0 1px 3px rgba(0,0,0,0.2);
-webkit-border-radius: 5px;
}
Conclusion
Just like HTML5 new tags, these methods are not being used by developers just to support earlier browser versions, with Mozilla Firefox and IE failing to support a bundle of attributes, these image free styling methods are being ignored completely, using CSS than images will decrease the bandwidth consumption and Load time drastically. You are just left with one question, whether to prioritize performance or browser support, it’s up to you to decide which one depending on the client and the project, as developers all we can do regarding this matter is to request user to upgrade their browsers.