网站首页
技术文章
客户案例
联系方式
信息搜索
深山工作室
>
用javascript美化Select,并获取相应的值
以下为详细代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3c.org/TR/1999/REC-html401-19991224/loose.dtd"> <HTML lang=zh-CN xmlns="http://www.w3.org/1999/xhtml"><HEAD><TITLE>用javascript美化Select,并获取相应的值</TITLE> <META http-equiv=Content-Type content="text/html; charset=gb2312"> <META http-equiv=Content-Language content=zh-CN> <STYLE type=text/css>* { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px } BODY { MARGIN: 50px } .iDiv { BORDER-RIGHT: #aaa 1px solid; BORDER-TOP: #aaa 1px solid; FONT-SIZE: 12px; BACKGROUND: url(images/select_bg.gif) no-repeat 100% 0px; VERTICAL-ALIGN: middle; BORDER-LEFT: #aaa 1px solid; CURSOR: default; COLOR: #333; TEXT-INDENT: 4px; LINE-HEIGHT: 20px; BORDER-BOTTOM: #aaa 1px solid; POSITION: absolute; HEIGHT: 20px } .iDiv_over { BACKGROUND-POSITION: 100% 100%; COLOR: #f96 } .iDiv_out { BACKGROUND-POSITION: 100% 0px; COLOR: #333 } .cDiv { BORDER-RIGHT: silver 1px solid; BORDER-TOP: silver 1px solid; Z-INDEX: 1; BACKGROUND: #f7f7f7; OVERFLOW: auto; BORDER-LEFT: silver 1px solid; CURSOR: default; BORDER-BOTTOM: silver 1px solid; POSITION: absolute; moz-user-select: none } .cDiv UL { PADDING-RIGHT: 0px; PADDING-LEFT: 0px; FONT-SIZE: 12px; PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-TOP: 0px; listStyle: none } .cDiv UL LI { TEXT-INDENT: 4px; LINE-HEIGHT: 20px; HEIGHT: 20px } </STYLE> <SCRIPT> function $() { return document.getElementById(arguments[0]); } //取得外部class的属性值 function getCurrentStyle(o) { return o.currentStyle||document.defaultView.getComputedStyle(o,null); } var SetAllSelects = { Offset:function(e) { var t = e.offsetTop; var l = e.offsetLeft; var w = e.offsetWidth; var h = e.offsetHeight; while(e = e.offsetParent) { t += e.offsetTop; l += e.offsetLeft; } return {top:t, left:l, width:w, height:h}; }, setCreated:function(obj,status) { //设置属性 obj.setAttribute("childCreated",status); }, getCreated:function(obj) { //获取属性 var status = obj.getAttribute("childCreated"); if(status == null) { status = ""; } return status; }, setSelectStyle:function(obj,idnum,showHeight) { if(obj.id == null || obj.id == "") { obj.id = "selectID_"+idnum; } var offset = this.Offset(obj); obj.style.visibility = "hidden"; var mainDiv = document.createElement("div"); var iDiv = document.createElement("div"); var js_select_; var _this = this; iDiv.className = "iDiv"; iDiv.id = js_select_+obj.id; iDiv.style.width = offset.width + "px"; iDiv.style.top = offset.top + "px"; iDiv.style.left = offset.left + "px"; this.setCreated(iDiv,""); mainDiv.appendChild(iDiv); var tValue = obj.options[obj.selectedIndex].innerHTML; iDiv.innerHTML = tValue; iDiv.onmouseover = function() { iDiv.className = "iDiv iDiv_over"; } iDiv.onmouseout = function() { iDiv.className = "iDiv iDiv_out"; } iDiv.onclick = function() { var created = _this.getCreated(this); if (created != "") { if (created == "open") { this.nextSibling.style.display = "none"; _this.setCreated(this,"close"); } else { _this.setCreated(this,"open"); var arrLiObj = this.nextSibling.getElementsByTagName("li"); var selOjbIndex = 0; for(var i=0;i<arrLiObj.length;i++) { var status = arrLiObj[i].getAttribute("liSelected"); if(status == null) { status = ""; } if(status == "selected") { selOjbIndex = i; break; } } arrLiObj[selOjbIndex].style.background = "#fff"; arrLiObj[selOjbIndex].style.color = "#000"; this.nextSibling.style.display = "block"; } } else { _this.setCreated(this,"open"); var cDiv = document.createElement("div"); cDiv.className = "cDiv"; cDiv.style.width = offset.width + "px"; cDiv.style.height = obj.options.length * 20 + "px"; if(parseInt(cDiv.style.height)>showHeight) { cDiv.style.height = showHeight + "px"; } cDiv.style.top = (offset.top+parseInt(getCurrentStyle(this).height)+1) + "px"; cDiv.style.left = offset.left + "px"; cDiv.onselectstart = function() {return false;}; var uUl = document.createElement("ul"); cDiv.appendChild(uUl); mainDiv.appendChild(cDiv); for (var i=0;i<obj.options.length;i++) { var lLi = document.createElement("li"); lLi.id = obj.options[i].value; lLi.innerHTML = obj.options[i].innerHTML; lLi.sValue = obj.options[i].value; uUl.appendChild(lLi); } var liObj = uUl.getElementsByTagName("li"); if(liObj.length>0) { for (var j=0;j<obj.options.length;j++) { liObj[j].onmouseover = function() { var arrLiObj = this.parentNode.getElementsByTagName("li"); for(var i=0;i<arrLiObj.length;i++) { var status = ""; var _background = "#ccc"; var _color = "#fff"; if(arrLiObj[i] != this) { _background = "#fff"; _color = "#000"; status = "selected"; } arrLiObj[i].style.background = _background; arrLiObj[i].style.color = _color; arrLiObj[i].setAttribute("liSelected",status); } } liObj[j].onclick = function() { obj.options.length = 0; obj.options[0] = new Option(this.innerHTML,this.sValue); this.parentNode.parentNode.style.display = "none"; _this.setCreated(this.parentNode.parentNode.previousSibling,"close"); iDiv.innerHTML = this.innerHTML; }; liObj[0].style.background = "#ccc"; liObj[0].style.color = "#fff"; liObj[0].setAttribute("liSelected","selected"); } } } } document.body.appendChild(mainDiv); }, setAllSelectStyle:function() { var s = document.getElementsByTagName("select"); for (var i=0; i<s.length; i++) { if(s[i].className == "select") { this.setSelectStyle(s[i],i,200); } } } } document.onclick = function(e) { e = e || window.event; var target = e.target || event.srcElement; var s = document.getElementsByTagName("select"); var js_select_; for (var i=0; i<s.length; i++) { if(s[i].className == "select") { var objdivtmp = $(js_select_+s[i].id); var created = SetAllSelects.getCreated(objdivtmp); if (created == "open") { if(target != objdivtmp) { objdivtmp.nextSibling.style.display = "none"; SetAllSelects.setCreated(objdivtmp,"close"); } } } } } window.onload = function() { SetAllSelects.setAllSelectStyle(); } </SCRIPT> <META content="MSHTML 6.00.5730.13" name=GENERATOR></HEAD> <BODY> <FORM><SELECT> <OPTION selected>这一只不需要美化</OPTION> <OPTION>选择1_1</OPTION> <OPTION>选择1_2</OPTION></SELECT> <SELECT class=select> <OPTION selected>要美化的就加class</OPTION> <OPTION>选择2_1</OPTION> <OPTION>选择2_22_22_22_2</OPTION> <OPTION>选择2_22_22_22_3</OPTION></SELECT> <BR><BR><BR><SELECT class=select> <OPTION value=3_1 selected>拿这一只来证明取值和取文字都没有问题</OPTION> <OPTION value=3_2>选择3_22_22_22_2</OPTION> <OPTION value=3_3>选择3_22_22_22_3</OPTION> <OPTION value=3_4>选择3_22_22_22_4</OPTION> <OPTION value=3_5>选择3_22_22_22_5</OPTION> <OPTION value=3_6>选择3_22_22_22_6</OPTION> <OPTION value=3_7>选择3_22_22_22_7</OPTION> <OPTION value=3_8>选择3_22_22_22_8</OPTION> <OPTION value=3_9>选择3_22_22_22_9</OPTION> <OPTION value=3_10>选择3_22_22_22_10</OPTION> <OPTION value=3_11>选择3_22_22_22_11</OPTION> <OPTION value=3_12>选择3_22_22_22_12</OPTION> <OPTION value=3_13>选择3_22_22_22_13</OPTION> <OPTION value=3_14>选择3_22_22_22_14</OPTION> <OPTION value=3_15>选择3_22_22_22_15</OPTION> <OPTION value=3_16>选择3_22_22_22_16</OPTION></SELECT> </FORM> <SCRIPT> function getValue() { var kk = document.getElementsByTagName('select')[2]; return kk.options[kk.selectedIndex].value; } function getTxt() { var kk = document.getElementsByTagName('select')[2]; return kk.options[kk.selectedIndex].innerHTML; } </SCRIPT> <BR><BR> <A onclick=alert(getValue()); href="#;">取第三个的值</A> <A onclick=alert(getTxt()); href="#;">取第三个的文本</A> </BODY></HTML>
前一页:
静态页面在文本框中输入数字,表格直接算出相应的结果
后一页:
凹陷文字
相关阅读
iframe里阻止_blank弹出新窗口的方法
jquery实现下拉加载更多
静态网站利用微信URL Scheme生成的ticket从浏览器h5跳到微信小程序完整代码
jquery获得当前所有input表单数据并进行序列化的各种问题与解决方案serialize与serializeArray的区别分析
查询某个字符在字符串中出现的位置数组
jquery设置或获取修改classname
微信小程序转uni-app项目
uniapp的rich-text组件注入的a标签点击跳转处理
更多>>
表单特效相关信息
input文本输入框只能输入数字或字母或汉字等
用于深山在线投票的一个javascript统计checkbox现在选中的个数一边点复选框一边验证并计算现在选了多少个复选框
利用javascript简短功能就可以检查form表单中的元素是否已经填写
javascript日期验证比较
javascript 根据汉字拼音首字母快速定位下拉列表
更多>>
最新添加
dw里面查找替换使用正则删除sqlserver里面的CONSTRAINT
Android移动端自动化测试:使用UIAutomatorViewer与Selenium定位元素
抖音直播音挂载小雪花 懂车帝小程序
javascript获取浏览器指纹可以用来做投票
火狐Mozilla Firefox出现:无法载入您的Firefox配置文件 它可能已经丢失 或是无法访问 问题解决集合处理办法
百度小程序开发
HTML
微信小程序开发
微信公众号开发
uni-app
asp函数库
ASP
下载类信息
DIV+CSS
个人空间
代码生成
SEO搜索引擎忧化
asp.net
电商
python
页面特效
表格特效
导航菜单
图形特效
表单特效
时间日期
色彩类别
链接特效
网页特效
系统硬件
网站公告
网页学习
技术类文章
网站类信息
旅行社网站案例
旅行社微信案例
头条抖音小程序案例
百度小程序案例
微信小程序案例
小程序案例
旅行社网站案例
投票案例
企业网站建设案例
Copyright ©
深山工作室
All Rights Reserved
服务QQ:
565449214
手机:
13961347334
ICP备案:
苏ICP备15019627号
苏公网安备 32070502010230号
网站首页
业务范围
服务案例
投票系统
联系方式
电话联系