JS 下拉框长度控制

yangguang6876 2011-02-23 03:19:07
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd ">
<html xmlns="http://www.w3.org/1999/xhtml ">

<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<script type="text/javascript">
function FixWidth(selectObj){
var newSelectObj = document.createElement("select");
newSelectObj = selectObj.cloneNode(true);
newSelectObj.setAttribute("ID", "aa");
newSelectObj.selectedIndex = selectObj.selectedIndex;
newSelectObj.onmouseover = null;
var e = selectObj;
var absTop = e.offsetTop;
var absLeft = e.offsetLeft;
while(e = e.offsetParent){
absTop += e.offsetTop;
absLeft += e.offsetLeft;
}
var widthTemp = "";
//if(absLeft >= 200px){
// widthTemp ="";
// }else{
// widthTemp = 200px;
// }
with (newSelectObj.style){
position = "absolute";
top = absTop + "px";
left = absLeft + "px";
width = widthTemp;
}
var rollback = function(){ RollbackWidth(selectObj, newSelectObj); };
newSelectObj.onmouseout= rollback;//新增加的事件,解决一处BUG
newSelectObj.focus();
newSelectObj.onfocus = function(){ newSelectObj.onmouseout=null; };//新增加的事件,解决BUG
newSelectObj.onblur = rollback;
newSelectObj.onchange = rollback;
selectObj.style.visibility = "hidden";
document.body.appendChild(newSelectObj);
}
function RollbackWidth(selectObj, newSelectObj){
selectObj.selectedIndex = newSelectObj.selectedIndex;
selectObj.style.visibility = "visible";
document.body.removeChild(newSelectObj);
}
</script>
</head>

<body>

<form method="post">
<select name="Select1" style="width:200px;" onmouseover="FixWidth(this)">
<option id="C" title="this is C">CCC发送</option>

</div>
</form>

</body>

</html>

上面是我写的一段代码,可以实现鼠标移动到上面自动伸长,但是如果option 值小于固定长度就会变短。我现在想让它不变短,请各位大大帮帮忙了。也就是说如果option 值长度大于设定的长度,鼠标滑过就会自动伸长(这部分现在是可以的),如果小于固定的长度鼠标滑过长度不变(这部分未解决)。
...全文
697 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd ">
<html xmlns="http://www.w3.org/1999/xhtml ">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<META NAME="修改完成" CONTENT="theforever(碧海情天,断水寒刀),赵亮">
<meta http-equiv="Email" content="theforever·163。com">
<meta http-equiv="Blog" content="blog·csdn·net/theforever">
<title>theforever_碧海情天_修改_自动调整宽度并有最小宽度的SELECT</title>
<script type="text/javascript">
function FixWidth(selectObj) {
var newSelectObj = document.createElement("select");
newSelectObj = selectObj.cloneNode(true);
newSelectObj.setAttribute("id", "theforever_csdn");
newSelectObj.selectedIndex = selectObj.selectedIndex;
newSelectObj.onmouseover = null;
var e = selectObj;
var absTop = e.offsetTop, absLeft = e.offsetLeft;
while (e = e.offsetParent) {
absTop += e.offsetTop;
absLeft += e.offsetLeft;
}
with(newSelectObj.style) {
position = "absolute";
top = absTop + "px";
left = absLeft + "px";
width = "";
}
var rollback = function() {
RollbackWidth(selectObj, newSelectObj);
};
newSelectObj.onmouseout = rollback; //新增加的事件,解决一处BUG
newSelectObj.focus();
newSelectObj.onfocus = function() {
newSelectObj.onmouseout = null;
}; //新增加的事件,解决BUG
newSelectObj.onblur = rollback;
newSelectObj.onchange = rollback;
selectObj.style.visibility = "hidden";
document.body.appendChild(newSelectObj);
if(newSelectObj.clientWidth<200) newSelectObj.style.width="200px";
}
function RollbackWidth(selectObj, newSelectObj) {
selectObj.selectedIndex = newSelectObj.selectedIndex;
selectObj.style.visibility = "visible";
document.body.removeChild(newSelectObj);
}
</script>
</head>
<body>
<form method="post">
<select name="Select1" style="width:200px;" onmouseover="FixWidth(this)">
<option id="C" title="this is C">CCC发送CCCCC发送</option>
<option id="D" title="this is D">ddd送ddd送dd</option>
</div>
</form>
</body>
</html>

马老虎 2011-02-23
  • 打赏
  • 举报
回复
使用DIV模拟 下拉框吧!
这个比较好控制!
gouhan02 2011-02-23
  • 打赏
  • 举报
回复
那就不要select控件了,自己写一个div控件。

87,910

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧