select收藏

<html>

<head>

<script type="text/javascript">

var childCreate=false;

function Offset(e)

//取标签的绝对位置

{

var t = e.offsetTop;

var l = e.offsetLeft;

var w = e.offsetWidth;

var h = e.offsetHeight-2;

alert(t);

while(e=e.offsetParent)

{

  t+=e.offsetTop;

  l+=e.offsetLeft;

}

 

return {

  top : t,

  left : l,

  width : w,

  height : h

}

}

function loadselect(obj){

//第一步:取得select所在的位置

var offset=Offset(obj);

//第二步:将真的select隐藏

obj.style.display="none";

//第三步:虚拟一个div出来代替select

var iDiv = document.createElement("div");

  iDiv.id="selectof" + obj.name;

  iDiv.style.position = "absolute";

  iDiv.style.width=offset.width + "px";

  iDiv.style.height=offset.height + "px";

  iDiv.style.top=offset.top + "px";

  iDiv.style.left=offset.left + "px";

  iDiv.style.background="url(http://www.zcool.com.cn/pic/png5/130/pixelicious_001.png) no-repeat right -6px";

  iDiv.style.border="1px solid #ccc";

  iDiv.style.fontSize="12px";

  iDiv.style.lineHeight=offset.height + "px";

  iDiv.style.textIndent="4px";

document.body.appendChild(iDiv);

//第四步:将select中默认的选项显示出来

var tValue=obj.options[obj.selectedIndex].innerHTML;

iDiv.innerHTML=tValue;

//第五步:模拟鼠标点击

iDiv.οnmοuseοver=function(){//鼠标移到

  iDiv.style.background="url(http://www.zcool.com.cn/pic/png5/130/pixelicious_001.png) no-repeat right -6px";

}

iDiv.οnmοuseοut=function(){//鼠标移走

  iDiv.style.background="url(http://www.zcool.com.cn/pic/png5/130/pixelicious_001.png) no-repeat right -6px";

}

iDiv.οnclick=function(){//鼠标点击

  if (document.getElementById("selectchild" + obj.name)){

  //判断是否创建过div

   if (childCreate){

    //判断当前的下拉是不是打开状态,如果是打开的就关闭掉。是关闭的就打开。

    document.getElementById("selectchild" + obj.name).style.display="none";

    childCreate=false;

   }else{

    document.getElementById("selectchild" + obj.name).style.display="";

    childCreate=true;

   }

  }else{

   //初始一个div放在上一个div下边,当options的替身。

   var cDiv = document.createElement("div");

   cDiv.id="selectchild" + obj.name;

   cDiv.style.position = "absolute";

   cDiv.style.width=offset.width + "px";

   cDiv.style.height=obj.options.length *20 + "px";

   cDiv.style.top=(offset.top+offset.height+2) + "px";

   cDiv.style.left=offset.left + "px";

   cDiv.style.background="#f7f7f7";

   cDiv.style.border="1px solid silver";

   var uUl = document.createElement("ul");

   uUl.id="uUlchild" + obj.name;

   uUl.style.listStyle="none";

   uUl.style.margin="0";

   uUl.style.padding="0";

   uUl.style.fontSize="12px";

   cDiv.appendChild(uUl);

   document.body.appendChild(cDiv);  

   childCreate=true;

   for (var i=0;i<obj.options.length;i++){

    //将原始的select标签中的options添加到li中

    var lLi=document.createElement("li");

    lLi.id=obj.options[i].value;

    lLi.style.textIndent="4px";

    lLi.style.height="20px";

    lLi.style.lineHeight="20px";

    lLi.innerHTML=obj.options[i].innerHTML;

    uUl.appendChild(lLi);

   }

   var liObj=document.getElementById("uUlchild" + obj.name).getElementsByTagName("li");

   for (var j=0;j<obj.options.length;j++){

    //为li标签添加鼠标事件

    liObj[j].οnmοuseοver=function(){

     this.style.background="gray";

     this.style.color="white";

    }

    liObj[j].οnmοuseοut=function(){

     this.style.background="white";

     this.style.color="black";

    }

    liObj[j].οnclick=function(){

     //做两件事情,一是将用户选择的保存到原始select标签中,要不做的再好看表单递交后也获取不到select的值了。

     obj.options.length=0;

     obj.options[0]=new Option(this.innerHTML,this.id);

     //同时我们把下拉的关闭掉。

     document.getElementById("selectchild" + obj.name).style.display="none";

     childCreate=false;

     iDiv.innerHTML=this.innerHTML;

    }

   }

  }

}

}

</script>

<style type="text/css">

select{width:200px;height:20px;}

</style>

</head>

<body>

  <h1>用javascript模拟select达到美化效果</h1>

<form name="f">

 

   <select id="province" name="province">

    <option value="10">江西</option>

    <option value="11">福建</option>

    <option value="12">广东</option>

    <option value="13">浙江</option>

    <option value="13">浙江</option>

    <option value="13">北京</option>

    <option value="13">上海</option>

    <option value="13">浙江</option>

    <option value="13">浙江</option>

    <option value="13">浙江</option>

    <option value="13">浙江</option>

    <option value="13">浙江</option>

   </select>

</form>

  <script type="text/javascript">

   loadselect(document.f.province);

  </script>

 

<br>sdsf<

<form name="frm">

<select name="s1" size="1" onChange="redirec1(document.frm.s1.options.selectedIndex)">

 <option selected >浙江</option>

 <option >江苏</option>

</select>

<select name="s2" size="1" onChange="redirec2(document.frm.s1.options.selectedIndex,document.frm.s2.options.selectedIndex)">

 <option selected>杭州</option>

<option>金华</option>

</select>

<select name="s3" size="1">

 <option selected>富阳</option>

<option>萧山</option>

</select>

</form>

<script language="javascript">

var select2 = new Array(new Array(new Option("杭州"),new Option("金华")),new Array(new Option("苏州"),new Option("连云港")));

var select3 = new Array(new Array(new Array(new Option("富阳"),new Option("萧山")),new Array(new Option("永康"),new Option("义务"))),new Array(new Array(new Option("aa"),new Option("aaa"),new Option("aaaa"),new Option("aaaaa")),new Array(new Option("bb"),new Option("bbb"))));

function redirec1(x)

{

 var temp = document.frm.s2; 

temp.length=0

 for (i=0;i<select2[x].length;i++)

 {

  temp.options[i]=new Option(select2[x][i].text);

 }

redirec2(document.frm.s1.options.selectedIndex,document.frm.s2.options.selectedIndex)

}

function redirec2(x,y)

{

 var temp = document.frm.s3; 

temp.length=0

 for (i=0;i<select3[x][y].length;i++)

 {

  temp.options[i]=new Option(select3[x][y][i].text);

 }

}

</script> 

</body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值