Version 10 (modified by 14 years ago) ( diff ) | ,
---|
Styling Form Controls Using Pseudo Classes
WebKit provides a way to give CSS styles to form controls. Some form controls can be styled through pseudo classes. This article will illustrate how we can customize their appearances using the pseudo classes.
Note: These pseudo classes are not standardized and we might change the behavior in the future.
<progress>
You can customize <progress>
element by -webkit-progress-bar-value
pseudo class.
An example following:
progress.custom { -webkit-appearance: none; background-color: blue; } progress.custom::-webkit-progress-bar-value { background-color: red; }
In this example, we first disable the default visual by -webkit-appearance: none
,
then give styles, one for <progress>
element itself, another for its "bar" part.
With this tyle, following HTML fragment...
<progress class="custom" min="0" max="100" value="30" />
...looks like:
Of course, we can also set properties other than background-color
.
<meter>
As <progress>
, <meter>
can be customized by pseudo classes.
But it's more complicated because <meter>
has three different 3 states (optimal
, suboptimal
and even-less-good
)
and 2 directions (horizontal
and vertical
).
WebKit defines 8 pseudo classes to handle them:
meter.custom::-webkit-meter-horizontal-bar { background: gray; } meter.custom::-webkit-meter-horizontal-optimum-value { background: green; } meter.custom::-webkit-meter-horizontal-suboptimal-value { background: yellow; } meter.custom::-webkit-meter-horizontal-even-less-good-value { background: red; } meter.custom::-webkit-meter-vertical-bar { background: gray; } meter.custom::-webkit-meter-vertical-optimum-value { background: blue; } meter.custom::-webkit-meter-vertical-suboptimal-value { background: purple; } meter.custom::-webkit-meter-vertical-even-less-good-value { background: white; }
Note that background "bar" part has directions, but has no state.
With this style, following HTML fragment...
<meter class="custom" style="height:20px; width:80px;" min="0" max="100" low="30" high="60" optimum="100" value="90" ></meter> <meter class="custom" style="height:20px; width:80px;" min="0" max="100" low="30" high="60" optimum="100" value="30" ></meter> <meter class="custom" style="height:20px; width:80px;" min="0" max="100" low="30" high="60" optimum="100" value="10" ></meter> <meter class="custom" style="height:100px; width:80px;" min="0" max="100" low="30" high="60" optimum="100" value="90" ></meter> <meter class="custom" style="height:100px; width:80px;" min="0" max="100" low="30" high="60" optimum="100" value="50" ></meter> <meter class="custom" style="height:100px; width:80px;" min="0" max="100" low="30" high="60" optimum="100" value="10" ></meter>
...looks like:
<meter> variations
On Mac OS X, WebKit provide multiple built-in appearances for <meter>
.
-webkit-appearance: continuous-capacity-level-indicator;
(Default)-webkit-appearance: discrete-capacity-level-indicator;
-webkit-appearance: relevancy-level-indicator;
-webkit-appearance: rating-level-indicator;
You can find the rendering result in the test suite:
<input> element
TODO.
Form validation message
WebKit r82179 or older (Chrome 10 and 11)
A validation message consists of four div elements with pseudo classes and some nodes for message text. You can customize the appearance by changing the style of these pseudo classes.
<div> ::-webkit-validation-bubble ┣ <div> ::-webkit-validation-bubble-top-outer-arrow ┣ <div> ::-webkit-validation-bubble-top-inner-arrow ┗ <div> ::-webkit-validation-bubble-message ┣ <b> ┃ ┗ Text node for the validation message ┗ Text nodes and <br> elements for the title attribute value
Example
Suppose that you want to modify colors of the validation messages bubble. Add the following CSS declarations:
::-webkit-validation-bubble-message { color: <text-color>; background: none; background-color: <background-color>; border-color: <border-color>; } ::-webkit-validation-bubble-top-outer-arrow { border-bottom-color: <border-color>; } ::-webkit-validation-bubble-top-inner-arrow { border-bottom-color: <background-color>; }
The default appearance is defined around http://trac.webkit.org/browser/trunk/Source/WebCore/css/html.css?rev=81155#L588 .
WebKit r82180 or later
A validation message consists of four div elements with pseudo classes and some nodes for message text. You can customize the appearance by changing the style of these pseudo classes.
<div> ::-webkit-validation-bubble ┣ <div> ::-webkit-validation-bubble-arrow-clipper ┃ ┗ <div> ::-webkit-validation-bubble-arrow ┗ <div> ::-webkit-validation-bubble-message ┣ <b> ┃ ┗ Text node for the validation message ┗ Text nodes and <br> elements for the title attribute value
Example
Suppose that you want to modify colors of the validation messages bubble. Add the following CSS declarations:
::-webkit-validation-bubble-message { color: <text-color>; background: <background-color>; border-color: <border-color>; -webkit-box-shadow: 0 0 0 0; } ::-webkit-validation-bubble-arrow { background: <background-color>; border-color: <border-color>; -webkit-box-shadow: 0 0 0 0; }
The default appearance is defined around http://trac.webkit.org/browser/trunk/Source/WebCore/css/html.css?rev=82180#L588 .
Attachments (3)
-
custom-meter.png
(8.0 KB
) - added by 14 years ago.
A <meter> screenshot
-
custom-progress.png
(5.6 KB
) - added by 14 years ago.
A <progress> screenshot
- validation-bubble-styled.png (5.7 KB ) - added by 13 years ago.
Download all attachments as: .zip