当前位置: 首页 > 图文教程 > 网络编程 > Javascript > 判断输入字符串为颜色类型的最优方法

Javascript
Dhtml:浏览大图时鼠标感应控制层滚动条的移动
初试javascript :贪吃蛇啊
只让输入数字的输入框
只能输入汉字的输入框
在JS中定义数组删除方法
在网页中使用realplayer播放rm文件
用层实现为网页中的图添加水印的效果
所见即所得编辑器 aynHTML 大全:(一)如何部署、嵌入、装载动态内容
JavaScript 收集的两个小代码!
JScript中正则表达函数的说明与应用
网页上内容导出到word里
关于开发在线网页编辑器按回车会输入<p>而不是<br>的解决方法
OOP In JS [JS脚本中的面向对象]
一个很通用的javascript的下拉菜单
将金额小写转化成汉字大写
VML Chart 控件
Js+Dhtml:WEB程序员简易开发工具包(预先体验版)
Javascript实例教程(21) OLE Automation(4)
javascript进行客户端数据的校验
JavaScript 小技巧(第三集)

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-10   浏览: 236 ::
收藏到网摘: n/a

一般情况下 如果我们判断一个给定字符串是否为颜色类型

需要考虑它是 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"都是有效的颜色值,但他们显示的颜色都是黑色 搞不懂 :(