CSS color names + alpha transparency

后端 未结 2 1300
隐瞒了意图╮
隐瞒了意图╮ 2021-02-18 16:59

Is it possible to define a color in CSS by its name plus an alpha transparency value?

I.e.:

#mytext { color: red 0.5 }

rather than reso

2条回答
  •  故里飘歌
    2021-02-18 17:24

    No. As of 2020, the CSS Colors specification only allows colors to be specified as:

    • Named colors
      • There's a set of 16 colors based on 4-bit color systems. This set is very limited and ugly to look at today.
      • CSS2 added X11+SVG named colors which are prettier, but don't allow you to specify an opacity value associated with the color.
      • There's also the named "System colors" but these are deprecated since modern OSes don't tend to use a single simple color for UI elements anymore.
    • RGB colors using:
      • 6-digit hex notation (#rrggbb)
      • 3-digit hex notation (#rgb)
      • rgb( r, g, b ) notation (using percentages or 0-255 numbers)
    • RGBA colors using:
      • 8-digit hex notation (#rrggbbaa)
      • rgba( r, g, b, a ) notation (Note that CSS4 requires rgb to accept 4 arguments but not all browsers support this), note that a is in the range 0-1.0 instead of 0-255.
    • HSL and HSLA colors:
      • hsl( h, s, l )
      • hsla( h, s, l, a )

    Each of these are mutually-exclusive.

    Color-names are less useful now than they were in the days of CSS1.x because the named colors (with the exception of orange) are all members of the old "16-color" display palette and generally look ugly today.

    If you want to use color names to improve readability then use comments, like so:

    color: rgb(0,0,0,0.5); /* semi-transparent black */
    

    (put the comment after the semi-colon because many CSS editors only preserve comments when they're located outside of property declarations).

    CSS3 adds more named-colors, including the 24-bit X11 color set, as well as the hsl(h,s,l) function, but still does not allow the mixing of named-colors and opacity values: http://www.w3.org/TR/css3-color/

提交回复
热议问题