When trying to modify the appearance of an HTML element, you may encounter !important CSS declarations that seem to prevent overrides from JavaScript. This can be frustrating, but it is possible to bypass these !important rules.
Using Inline Attribute
One method is to assign a 'style' attribute directly to the element. This style attribute should include the desired property and value. By appending !important to the value, you can override the external !important declaration.
element.setAttribute('style', 'display:inline !important');
Modifying CSS Text Property
Alternatively, you can modify the element's style object's 'cssText' property. This property contains the entire CSS code of the element. By assigning a new CSS code to this property, you can override the existing styles, including any !important rules.
element.style.cssText = 'display:inline !important';
Using jQuery Plugin
For a convenient solution, you can use my jQuery plugin called "important" available on GitHub. This plugin provides additional functions for manipulating !important rules in elements.
setProperty Method
Additionally, CSSOM (CSS Object Model) offers a method called 'setProperty' that allows you to set CSS properties with a specific priority. You can use this method to override !important rules.
element.style.setProperty('background-color', 'red', 'important');
By employing any of these methods, you can successfully override !important style rules using JavaScript.
The above is the detailed content of How to Override !important Style Rules in JavaScript?. For more information, please follow other related articles on the PHP Chinese website!