diff options
Diffstat (limited to 'build/easy-custom-radio-inputs')
-rw-r--r-- | build/easy-custom-radio-inputs/index.html | 127 |
1 files changed, 84 insertions, 43 deletions
diff --git a/build/easy-custom-radio-inputs/index.html b/build/easy-custom-radio-inputs/index.html index 58dc8f4..c96a469 100644 --- a/build/easy-custom-radio-inputs/index.html +++ b/build/easy-custom-radio-inputs/index.html @@ -1,62 +1,86 @@ <!doctype html> -<html lang="en" id="top"> +<html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="icon" href="data:,"> <title>Easy Custom Radio Inputs</title> - <link href="https://bt.ht/atom.xml" type="application/atom+xml" rel="alternate" title="Atom feed for blog posts" /> - <style>*{box-sizing:border-box;}body{font-family:sans-serif;margin:0 auto;max-width:650px;padding:1rem;}img{max-width:100%;}pre{overflow:auto;}table{text-align:left;width:100%;}</style> + <link href="/atom.xml" type="application/atom+xml" rel="alternate" title="Atom feed for blog posts" /> + <link href="/rss.xml" type="application/rss+xml" rel="alternate" title="RSS feed for blog posts" /> +<style>*{box-sizing:border-box;}body{font-family:sans-serif;line-height:1.33;margin:0 auto;max-width:650px;padding:1rem;}img{max-width:100%;}pre{border:1px solid;overflow:auto;padding:5px;}table{text-align:left;width:100%;}.footnotes{font-size:90%;}</style> </head> <nav> - <a href="#menu">Menu ↓</a> + <a href="#menu">Menu ↓</a> </nav> <main> -<h1>Easy Custom Radio Inputs</h1> +<h1 id="easy-custom-radio-inputs">Easy Custom Radio Inputs</h1> + <p>2019-01-21</p> -<p>Default radio inputs are notoriously horrible looking and are something designers tend to over-think when trying to customize them. Let's walk through how to create custom radio buttons with <em>pure CSS</em>, while still preserving performance and accessibility.</p> -<h2>The Final Product</h2> + +<p>Default radio inputs are notoriously horrible looking and are something designers tend to over-think when trying to customize them. Let’s walk through how to create custom radio buttons with <em>pure CSS</em>, while still preserving performance and accessibility.</p> + +<h2 id="the-final-product">The Final Product</h2> + <p>This is what we will be designing:</p> + <p><img src="/public/images/custom-radio-inputs.png" alt="Custom radio inputs" /></p> + <p><a href="https://codepen.io/bradleytaunt/pen/oNjwMyX">Live CodePen Example</a></p> -<hr /> -<h2>The bones of our radio inputs (HTML)</h2> -<pre><code><input class="radio-btn" name="radio-collection" id="radio-1" type="radio"> -<label class="radio-label" for="radio-1"><span>I am very satisfied</span></label> -<input class="radio-btn" name="radio-collection" id="radio-2" type="radio"> -<label class="radio-label" for="radio-2"><span>I am satisfied</span></label> +<hr/> + +<h2 id="the-bones-of-our-radio-inputs-html">The bones of our radio inputs (HTML)</h2> + +<pre><code><input class="radio-btn" name="radio-collection" id="radio-1" type="radio"> +<label class="radio-label" for="radio-1"><span>I am very satisfied</span></label> -<input class="radio-btn" name="radio-collection" id="radio-3" type="radio"> -<label class="radio-label" for="radio-3"><span>I am indifferent</span></label> +<input class="radio-btn" name="radio-collection" id="radio-2" type="radio"> +<label class="radio-label" for="radio-2"><span>I am satisfied</span></label> -<input class="radio-btn" name="radio-collection" id="radio-4" type="radio"> -<label class="radio-label" for="radio-4"><span>I am unsatisfied</span></label> +<input class="radio-btn" name="radio-collection" id="radio-3" type="radio"> +<label class="radio-label" for="radio-3"><span>I am indifferent</span></label> -<input class="radio-btn" name="radio-collection" id="radio-5" type="radio"> -<label class="radio-label" for="radio-5"><span>I am very unsatisfied</span></label> +<input class="radio-btn" name="radio-collection" id="radio-4" type="radio"> +<label class="radio-label" for="radio-4"><span>I am unsatisfied</span></label> + +<input class="radio-btn" name="radio-collection" id="radio-5" type="radio"> +<label class="radio-label" for="radio-5"><span>I am very unsatisfied</span></label> </code></pre> -<p>I know it looks like a lot is going on here, but it's pretty straightforward so let's unpackage line by line:</p> -<h3>Radio inputs</h3> -<pre><code><input class="radio-btn" name="radio-collection" id="radio-1" type="radio"> + +<p>I know it looks like a lot is going on here, but it’s pretty straightforward so let’s unpackage line by line:</p> + +<h3 id="radio-inputs">Radio inputs</h3> + +<pre><code><input class="radio-btn" name="radio-collection" id="radio-1" type="radio"> </code></pre> + <p>This is the default <code>radio</code> input. We give it:</p> + <ul> <li>a <code>name</code> (inputs with a shared <code>name</code> are grouped together)</li> <li>an <code>id</code> (so our label can target this input)</li> <li>a <code>class</code> (so we can style it later)</li> </ul> -<p><strong>Important</strong>: be sure to have a unique <code>id</code> for each input so your labels don't end up connected to multiple radios. In this demo we are simply incrementing them by one.</p> -<h3>Labels</h3> -<p>Adding the labels is fairly straightforward, we just include the corresponding input's <code>id</code> in the label's <code>for</code> attribute. The label content is wrapped in a <code>span</code> - which I will explain the reasoning for later.</p> + +<p><strong>Important</strong>: be sure to have a unique <code>id</code> for each input so your labels don’t end up connected to multiple radios. In this demo we are simply incrementing them by one.</p> + +<h3 id="labels">Labels</h3> + +<p>Adding the labels is fairly straightforward, we just include the corresponding input’s <code>id</code> in the label’s <code>for</code> attribute. The label content is wrapped in a <code>span</code> - which I will explain the reasoning for later.</p> + <p>For styling purposes we also add the <code>radio-label</code> class.</p> -<pre><code><label class="radio-label" for="radio-1"><span>I am very satisfied</span></label> + +<pre><code><label class="radio-label" for="radio-1"><span>I am very satisfied</span></label> </code></pre> -<p>This is looking pretty terrible - but that's nothing some good ol' CSS can't fix!</p> -<h2>The flesh of our radio inputs (CSS)</h2> + +<p>This is looking pretty terrible - but that’s nothing some good ol’ CSS can’t fix!</p> + +<h2 id="the-flesh-of-our-radio-inputs-css">The flesh of our radio inputs (CSS)</h2> + <p>First we give some basic styling to our <code>label</code> and <code>input</code> classes (along with hover states). The <code>radio</code> element is actually hidden from view, but by using the <code>visibility</code> attribute we still keep it accessible for screen-readers.</p> + <pre><code>.radio-label { background: white; border: 1px solid #eee; @@ -66,7 +90,7 @@ display: inline-block; font-weight: 600; margin: 0 auto 10px; - /* This 65px padding makes room for the custom input */ + /* This 65px padding makes room for the custom input */ padding: 20px 20px 20px 65px; position: relative; transition: .3s ease all; @@ -80,44 +104,55 @@ visibility: hidden; } </code></pre> -<p>Remember that <code>span</code> element inside the label? We set it's <code>user-select</code> property to <code>none</code> so we avoid any possible issue with the user selecting the text on-click:</p> + +<p>Remember that <code>span</code> element inside the label? We set it’s <code>user-select</code> property to <code>none</code> so we avoid any possible issue with the user selecting the text on-click:</p> + <pre><code>.radio-label span { -webkit-user-select: none; -moz-user-select: none; user-select: none; } </code></pre> + <p>Next we include the default empty selection element (to mimic the original radio input) via a pseudo element:</p> + <pre><code>.radio-label:before { background: #eee; border-radius: 50%; - content:''; + content:''; height: 30px; left: 20px; position: absolute; - /* Half the height of it's parent minus half of it's own height */ + /* Half the height of it's parent minus half of it's own height */ top: calc(50% - 15px); transition: .3s ease background-color; width: 30px; } </code></pre> -<h2>A Few Final Steps</h2> + +<h2 id="a-few-final-steps">A Few Final Steps</h2> + <p>The final step is adding the custom styling for when an <code>input</code> item is selected (<code>:checked</code>).</p> + <p>You will notice the use of a <code>base64</code> element for the custom checkmark - feel free to subsitute this for an actual image or none at all (this is just my personal design preference).</p> + <pre><code>.radio-btn:checked + .radio-label { background: #ECF5FF; border-color: #4A90E2; } .radio-btn:checked + .radio-label:before { background-color: #4A90E2; - background-image: url(''); + background-image: url(''); background-repeat: no-repeat; background-position: center; background-size: 15px; } </code></pre> -<p><strong>And that's it.</strong></p> + +<p><strong>And that’s it.</strong></p> + <p>For easier reference the entire CSS file can be found below:</p> + <pre><code>.radio-label { background: white; border: 1px solid #eee; @@ -138,7 +173,7 @@ .radio-label:before { background: #eee; border-radius: 50%; - content:''; + content:''; height: 30px; left: 20px; position: absolute; @@ -161,16 +196,21 @@ } .radio-btn:checked + .radio-label:before { background-color: #4A90E2; - background-image: url(''); + background-image: url(''); background-repeat: no-repeat; background-position: center; background-size: 15px; } </code></pre> -<hr /> -<h2>But wait - we can get even fancier!</h2> -<p>Since this demo is based off a survey-type questionaire, wouldn't it be interesting to give the different selectable options their own styling based on their context? Take a look at the further customized version below:</p> + +<hr/> + +<h2 id="but-wait---we-can-get-even-fancier">But wait - we can get even fancier!</h2> + +<p>Since this demo is based off a survey-type questionaire, wouldn’t it be interesting to give the different selectable options their own styling based on their context? Take a look at the further customized version below:</p> + <p>We can do so by adding <code>positive</code>, <code>neutral</code> and <code>negative</code> class names to the radio inputs with their own respective properties:</p> + <pre><code>.radio-btn.positive:checked + .radio-label { background: #EAFFF6; border-color: #32B67A; @@ -179,7 +219,7 @@ background-color: #32B67A; } .radio-btn.neutral:checked + .radio-label:before { - background-image: url(''); + background-image: url(''); } .radio-btn.negative:checked + .radio-label { background: #FFF2F2; @@ -187,10 +227,11 @@ } .radio-btn.negative:checked + .radio-label:before { background-color: #E75153; - background-image: url(''); + background-image: url(''); } </code></pre> -<p>I hope this shows new designers that simple custom radio inputs aren't so hard to implement after-all and can actually be pretty fun to design.</p> + +<p>I hope this shows new designers that simple custom radio inputs aren’t so hard to implement after-all and can actually be pretty fun to design.</p> <footer role="contentinfo"> <h2>Menu Navigation</h2> <ul id="menu"> |