Join the social network of Tech Nerds, increase skill rank, get work, manage projects...
 
  • Learn how to create a FlipFlop button using Pure CSS

    • 1
    • 1
    • 0
    • 0
    • 0
    • 0
    • 0
    • 0
    • 1.17k
    Comment on it

    Hii,
     In this blog, I am going to  share an example in which i have created a pure CSS Flip Flop button using few CSS properties like transitions, transforms, checkbox functionality and animations.
    Flip flop buttons created using Pure CSS can be very useful as it is very light weighted,easy to implement. 

    If you are asked to create a FlipFlop design, no doubt you will prefer to use some scripting language like javascript or jquery too.


    No doubt you can create it using any scripting language but if you want to learn how to create it using simple CSS properties then go though the example below.


    FlipFlop button created using images
     

    CSS:

    1. .switch {position: relative;display: block;vertical-align: top;width: 100px;height: 30px;padding: 3px;
    2. margin: 0 10px 10px 0;cursor: pointer;}
    3. .switch-input {position: absolute;top: 0;left: 0;opacity: 0;}
    4. .switch-label {position: relative;display: block;background-image: url(off.jpg);width:500px;height:411px;}
    5. .switch-input:checked ~ .switch-label {background-image: url("on.jpg");width:500px;height:411px;}


    HTML:

    1. <label class="switch">
    2. <input class="switch-input" type="checkbox" />
    3. <span class="switch-label" data-on="On" data-off="Off"></span>
    4. </label>

     

    FlipFlop button created without using any image
     

    CSS:

    1. .switch {
    2. position: relative;
    3. display: block;
    4. vertical-align: top;
    5. width: 100px;
    6. height: 30px;
    7. padding: 3px;
    8. margin: 0 10px 10px 0;
    9. background: linear-gradient(to bottom, #eeeeee, #FFFFFF 25px);
    10. background-image: -webkit-linear-gradient(top, #eeeeee, #FFFFFF 25px);
    11. border-radius: 18px;
    12. box-shadow: inset 0 -1px white, inset 0 1px 1px rgba(0, 0, 0, 0.05);
    13. cursor: pointer;
    14. }
    15. .switch-input {
    16. position: absolute;
    17. top: 0;
    18. left: 0;
    19. opacity: 0;
    20. }
    21. .switch-label {
    22. position: relative;
    23. display: block;
    24. height: inherit;
    25. font-size: 10px;
    26. text-transform: uppercase;
    27. background: #777779;
    28. color:#000;
    29. border-radius: inherit;
    30. box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.12), inset 0 0 2px rgba(0, 0, 0, 0.15);
    31. }
    32. .switch-label:before, .switch-label:after {
    33. position: absolute;
    34. top: 50%;
    35. margin-top: -.5em;
    36. line-height: 1;
    37. -webkit-transition: inherit;
    38. -moz-transition: inherit;
    39. -o-transition: inherit;
    40. transition: inherit;
    41. }
    42. .switch-label:before {
    43. content: attr(data-off);
    44. right: 11px;
    45. color: #000;
    46. text-shadow: 0 1px rgba(255, 255, 255, 0.5);
    47. }
    48. .switch-label:after {
    49. content: attr(data-on);
    50. left: 11px;
    51. color: #000;
    52. text-shadow: 0 1px rgba(0, 0, 0, 0.2);
    53. opacity: 0;
    54. }
    55. .switch-input:checked ~ .switch-label {
    56. background: #037CD5;
    57. box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.15), inset 0 0 3px rgba(0, 0, 0, 0.2);
    58. }
    59. .switch-input:checked ~ .switch-label:before {
    60. opacity: 0;
    61. }
    62. .switch-input:checked ~ .switch-label:after {
    63. opacity: 1;
    64. }
    65. .switch-handle {
    66. position: absolute;
    67. top: 4px;
    68. left: 4px;
    69. width: 28px;
    70. height: 28px;
    71. background: linear-gradient(to bottom, #FFFFFF 40%, #f0f0f0);
    72. background-image: -webkit-linear-gradient(top, #FFFFFF 40%, #f0f0f0);
    73. border-radius: 100%;
    74. box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);
    75. }
    76. .switch-handle:before {
    77. content: "";
    78. position: absolute;
    79. top: 50%;
    80. left: 50%;
    81. margin: -6px 0 0 -6px;
    82. width: 12px;
    83. height: 12px;
    84. background: linear-gradient(to bottom, #eeeeee, #FFFFFF);
    85. background-image: -webkit-linear-gradient(top, #eeeeee, #FFFFFF);
    86. border-radius: 6px;
    87. box-shadow: inset 0 1px rgba(0, 0, 0, 0.02);
    88. }
    89. .switch-input:checked ~ .switch-handle {
    90. left: 74px;
    91. box-shadow: -1px 1px 5px rgba(0, 0, 0, 0.2);
    92. }
    93. /* Transition
    94. ========================== */
    95. .switch-label, .switch-handle {
    96. transition: All 0.3s ease;
    97. -webkit-transition: All 0.3s ease;
    98. -moz-transition: All 0.3s ease;
    99. -o-transition: All 0.3s ease;
    100. }


    HTML:

    1. <label class="switch">
    2. <input class="switch-input" type="checkbox" />
    3. <span class="switch-label" data-on="On" data-off="Off"></span>
    4. <span class="switch-handle"></span>
    5. </label>

     

 0 Comment(s)

Sign In
                           OR                           
                           OR                           
Register

Sign up using

                           OR                           
Forgot Password
Reset Password
Fill out the form below and reset your password: