A to Z CSS: Enabled


:enabled and :disabled are pseudo classes that allow the styling of different states of form inputs, ones that are clickable or can have text entered into them (enabled) or those that can’t (disabled).

All form controls are enabled by default but can be disabled by adding the disabled attribute in HTML. This can also be manipulated by JavaScript based on conditions on the page.

Browser Support

:enabled and :disabled are supported in IE9+

Transcript

There’s a number of pseudo classes in CSS.

These pseudo classes help us style different states and target specific elements based on their relationship or position to other elements.

The :enabled and :disabled pseudo classes style form elements that can or cannot be filled in or selected.

An enabled element is one that can be clicked, selected, receive focus or accept text input – a disabled element is one that cannot.

Elements are enabled by default but can be disabled using the disabled attribute in HTML.

Enabled / Disabled form fields

The user agent provides some default styling for disabled elements. Let’s take a look

I’ve got two sets of inputs and buttons here.

They are both in their default state of enabled which we can demonstrate by styling them with the :enabled pseudo class, giving them a dark grey background and a blue text color.

If I now add the disabled attribute to the HTML of the first set of inputs, the user agent styles for disabled fields takes over and our :enabled styles do not as the inputs are no longer enabled. We can control the styling of disabled inputs in CSS with the :disabled pseudo class.

Use case

Let’s take a look at a real-world use case.

Here we have the payment step for ordering some food online. In this stage of the form, the payment method is requested and the choice is either cash or card.

If we want to pay by card, the fields for the card holder, card number, start date, expiry date and security code are enabled. If we want to pay with cash, these details aren’t needed and we can disable them. This can’t be done with CSS alone, but we can use a bit of Javascript or jQuery to handle the interaction.

When we change the payment method the script checks whether the radio button with the ID of cash is :checked. This is another pseudo class that determines state – in this case, the checked or unchecked state of a checkbox or radio button. If cash is checked, we add the disabled attribute to all the inputs and select menus in the card fields container. We also add an is-disabled class to the labels which will allow these to be given different styles too.

We can then style these in CSS, making the color of the text and the background of the inputs a light grey to show that they’re no longer enabled.

AtoZ CSS: Learn CSS and sharpen your front-end skills

AtoZ CSS is a video screencast series that tackles one CSS topic per letter of the alphabet. From auto to z-index, take a deep dive into a single property, value, selector or concept each week.

0 Comments

Submit a Comment

Your email address will not be published. Required fields are marked *

More News & Articles

The Essential Guide to Getting Started on Freelance Writing

The Essential Guide to Getting Started on Freelance Writing

Explore the lucrative and fulfilling world of freelance writing with our essential guide. Learn about specialties like blogging, social media, article, and technical writing. Build a portfolio, find work, set up your business, and discover the potential earnings. Embrace the freedom of working from home and follow tips for success in your dream career.

Securing Your Website: A DevOps Security Checklist

Securing Your Website: A DevOps Security Checklist

Learn how to secure your website with a comprehensive DevOps checklist. Dive into SSL/TLS encryption, password practices, and more. Discover the power of Content Security Policy and safeguard your online presence effectively.

EMAIL NEWSLETTER