在 HTML 中作为背景颜色输入时, 为什么某些随机字符串会产生颜色 ?
例如,bgcolor="chucknorris"
a 生产量a红色背景红背景:
<body bgcolor="chucknorris"> test </body>
相反,bgcolor="chucknorr"
a 生产量a黄色背景:
<body bgcolor="chucknorr"> test </body>
各种浏览器和平台都存在这种情况。
在 HTML 中作为背景颜色输入时, 为什么某些随机字符串会产生颜色 ?
例如,bgcolor="chucknorris"
a 生产量a红色背景红背景:
<body bgcolor="chucknorris"> test </body>
相反,bgcolor="chucknorr"
a 生产量a黄色背景:
<body bgcolor="chucknorr"> test </body>
各种浏览器和平台都存在这种情况。
当前回答
原因是浏览器可以不理解并试图将它转化为能理解的东西,
chucknorris
开始于c
在十六进进制中被识别的字符, 也正在将所有未识别的字符转换成0
!
苏chucknorris
六进制格式改为:c00c00000000
,所有其他字符成为0
和c
仍然在他们所在的地方...
现在他们被除以3RGB
(红色、绿色、蓝色)...R: c00c, G: 0000, B:0000
...
但是我们知道对RGB来说 有效的十六进制是两个字符 意思是R: c0, G: 00, B:00
因此,真正的结果是:
bgcolor="#c00000";
我还添加了图像中的步骤,作为你们快速参考:
其他回答
chucknorris
开始于c
,浏览器将它读取为十六进制值。
因为A、B、C、D、E和F是十六进制字符.
浏览器转换chucknorris
至十六进制值,C00C00000000
.
然后C00C00000000
十六进制值转换为RGB 英国GB格式( 由 3 组成 ) :
C00C00000000
⇒R:C00C, G:0000, B:0000
浏览器只需两位数来表示颜色 :
R:C00C, G:0000, B:0000
⇒R:C0, G:00, B:00
⇒C00000
最后,表演bgcolor = C00000
在 Web 浏览器中。
以下是一个例子:
<table>
<tr>
<td bgcolor="chucknorris" cellpadding="10" width="150" align="center">chucknorris</td>
<td bgcolor="c00c00000000" cellpadding="10" width="150" align="center">c00c00000000</td>
<td bgcolor="c00000" cellpadding="10" width="150" align="center">c00000</td>
</tr>
</table>
原因是浏览器可以不理解并试图将它转化为能理解的东西,
chucknorris
开始于c
在十六进进制中被识别的字符, 也正在将所有未识别的字符转换成0
!
苏chucknorris
六进制格式改为:c00c00000000
,所有其他字符成为0
和c
仍然在他们所在的地方...
现在他们被除以3RGB
(红色、绿色、蓝色)...R: c00c, G: 0000, B:0000
...
但是我们知道对RGB来说 有效的十六进制是两个字符 意思是R: c0, G: 00, B:00
因此,真正的结果是:
bgcolor="#c00000";
我还添加了图像中的步骤,作为你们快速参考:
很抱歉我不同意 但根据传统颜色的分解规则由Yuhong Bao张贴, chucknorris
无等于等于#CC0000
,而是#C00000
,一个非常相似但稍稍不同的红色色调。火狐 颜色Zilla 添加来核实这一点。
规则规定:
chucknorris0
chuc knor ris0
ch kn ri
C0 00 00
我利用这些规则正确解释了以下条件:
LuckyCharms
Luck
LuckBeALady
LuckBeALadyTonight
GangnamStyle
最初的回答者说颜色是#CC0000
其后编辑了答复,以列入更正。
浏览器正在试图转换chucknorris
十六进制颜色代码,因为它不是一个有效的值。
chucknorris
,除c
不是一个有效的十六进制值。c00c00000000
.这似乎主要是与Internet 探索器和歌剧院(12) 因为铬(31)和Firefox(26)都忽略了这一点。
P.S. 括号中的数字是我测试过的浏览器版本。
同样,拉伊尼坎特(印度恰克·诺里斯) 和黑色的阴影相反:
000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
在较轻的音符上
Chuck Norris不符合网络标准。 网络标准符合他的要求。 #BADA55
大多数浏览器将简单地忽略任何未缴- 颜色字符串中的十六进制值,以零取代非十六进制数字。
ChuCknorris
翻译为c00c0000000
。在此点,浏览器将把字符串分为三个相等的区块,显示红红, 绿绿色和蓝蓝色值 :c00c 0000 0000
。每一部分中的额外位数将被忽略,从而得出最终结果#c00000
这是红色的颜色。
注注,这样可以:否应用到 CSS 颜色解析, 该颜色解析遵循 CSS 标准 。
<p><font color='chucknorris'>Redish</font></p>
<p><font color='#c00000'>Same as above</font></p>
<p><span style="color: chucknorris">Black</span></p>