判断输入字符串为颜色类型的最优方法

2008-02-23 08:07:15来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

一般情况下 如果我们判断一个给定字符串是否为颜色类型,需要考虑它是 16进制代码(如 #ffffff) 或系统内部定义字符串(如buttonface、red、blue等) 或者是rgb()形式。如果我们依次去判断它的格式是否符合标准 那将相当的花费时间和代码工作。我在应用中发现了一个非常简单并且有效的办法,就是通过document.createElement()创建一个元素,将需判断的字符串写到这个标签内。
如 var oSpan = document.createElement("<span style='color:" strColor ";'></span>");
然后判断oSpan.style.color是否为空,是则该字符串strColor 就是非法颜色值,否则合法。

以下是例子:
<input type="text" id="oColor">
<br><br>
<input type="button" value=" 检查颜色代码 "onclick="display_Check(oColor.value)">

<script language="javascript">
<!--
function inspect_Color(strColor)
{
var oSpan = document.createElement("<span style='color:" strColor ";'></span>");
if(oSpan.style.color != "")
{
return true;
}
else
{
return false;
}
oSpan = null;
}

function display_Check(strColor)
{
if(inspect_Color(strColor))
{
alert(strColor " 是有效的颜色值");
}
else
{
alert(strColor " 无效");
}

}
//-->
</script>
可是输入类似 #fffabf , red, rgb(100,100,100) 等测试,是不是很方便啊?

需要注意的地方:
1 不能在创建完span后再去设置它的颜色。如果颜色字符串无效 那么程序将报错
2 测试时我发现 "aaa","bbb","ccc","ddd","eee","fff"都是有效的颜色值,但他们显示的颜色都是黑色 搞不懂.
关键词:
【推荐给好友】【关闭】
最新五条评论
查看全部评论
评论总数 0 条
您的评论
用户名: 新注册) 密 码: 匿名:
·用户发表意见仅代表其个人意见,并且承担一切因发表内容引起的纠纷和责任
·本站管理人员有权在不通知用户的情况下删除不符合规定的评论信息或留做证据
·请客观的评价您所看到的资讯,提倡就事论事,杜绝漫骂和人身攻击等不文明行为

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:用JavaScript实现仿Windows关机效果

下一篇:在JS中使用RecordSet对象的GetRows方法