解决IE8固定宽度下拉列表中option内容显示不全问题
来源:互联网 发布:小米账号破解软件 编辑:程序博客网 时间:2024/06/14 15:09
原文链接:http://clocker321.blog.163.com/blog/static/6350577200982794537757/
公司项目需要兼容IE8,在一个功能模块中用到了select下拉框并设置了宽度为固定值,在IE8浏览器中打开的的时候,因为option加载的内容长度>下拉框宽度,选择下拉框内容的时候并没有显示完全,如下图:
用了以上方法可完全显示出来,如上右图,zIndex=11;是我自己添加的,在css中是z-index:11,但是在js中就不管用了
详细代码(取自链接):
<!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 src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js" type="text/javascript"></script><script type="text/javascript">function FixWidth(selectObj){ var newSelectObj = document.createElement("select"); newSelectObj = selectObj.cloneNode(true); newSelectObj.selectedIndex = selectObj.selectedIndex; newSelectObj.id="newSelectObj"; var e = selectObj; var absTop = e.offsetTop; var 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 = "auto"; zIndex=11; } var rollback = function(){ RollbackWidth(selectObj, newSelectObj); }; if(window.addEventListener) { newSelectObj.addEventListener("blur", rollback, false); newSelectObj.addEventListener("change", rollback, false); } else { newSelectObj.attachEvent("onblur", rollback); newSelectObj.attachEvent("onchange", rollback); } selectObj.style.visibility = "hidden"; document.body.appendChild(newSelectObj); var newDiv = document.createElement("div"); with (newDiv.style) { position = "absolute"; top = (absTop-10) + "px"; left = (absLeft-10) + "px"; width = newSelectObj.offsetWidth+20; height= newSelectObj.offsetHeight+20;; background = "transparent"; zIndex=11; } document.body.appendChild(newDiv); newSelectObj.focus(); var enterSel="false"; var enter = function(){enterSel=enterSelect();}; newSelectObj.onmouseover = enter; var leavDiv="false"; var leave = function(){leavDiv=leaveNewDiv(selectObj, newSelectObj,newDiv,enterSel);}; newDiv.onmouseleave = leave;}function RollbackWidth(selectObj, newSelectObj){ selectObj.selectedIndex = newSelectObj.selectedIndex; selectObj.style.visibility = "visible"; if(document.getElementById("newSelectObj") != null){ document.body.removeChild(newSelectObj); }}function removeNewDiv(newDiv){ document.body.removeChild(newDiv);}function enterSelect(){ return "true";}function leaveNewDiv(selectObj, newSelectObj,newDiv,enterSel){ if(enterSel == "true" ){ RollbackWidth(selectObj, newSelectObj); removeNewDiv(newDiv); }}</script></head><body><form method="post"> <div style="width:100px; height:100px; margin:100px; padding:10px; background:gray;z-index: 10;" > <select name="Select1" style="width:80px;" onmouseover="FixWidth(this)"> <option id="A" >AAAAAAAAAAAAAAA</option> <option id="B" >BBBBBBBBBBBBBBB</option> <option id="C" >CCCCCCCCCCCCCCC</option> </select> </div></form></body></html>
还参考了另一种方法,链接:http://blog.csdn.net/itguaicai/article/details/42581021
$(function() { $(".ProductAttributesSelect").mouseover(function() { $(this).data("origWidth", $(this).css("width")).css("width", "auto"); }).mouseout(function() { $(this).css("width", $(this).data("origWidth")); }); });
这种方式虽然简单便捷,但是在用的时候就会发现鼠标移出select框去选择option时,select框恢复为原来的宽度,并不能进行选择,没有达到预期的目的
阅读全文
0 0
- 解决IE8固定宽度下拉列表中option内容显示不全问题
- 固定宽度下拉列表中option内容显示不全问题解决方法
- 固定宽度下拉列表中option内容显示不全问题解决方法
- 固定宽度下拉列表中option内容显示不全问题解决方法
- html固定宽度下拉框内容显示不全问题解决方法
- html固定宽度下拉框内容显示不全问题解决方法
- 解决下拉框内容显示不全问题
- IE8中select控件中的option显示不全解决方案
- jq 解决ie9以下 select宽度固定 option 显示不
- IE 6/7/8 BUG:下拉框select设宽度时option超出显示不全
- 解决GridView内容显示不全问题
- JavaScript解决select下拉框中的内容太长显示不全的问题
- 固定宽度的select下拉单,值过长导致显示不全的问题解决方案
- 解决ScrollView下嵌套ListView、GridView中内容显示不全的问题
- 【完美解决系列】Android在自定义Dialog中TextView内容显示不全的问题
- 解决select选项内容过长,文字显示不全的问题
- 下拉框中的内容显示不全
- WKWebView 内容显示不全问题
- 【bzoj3238】[Ahoi2013]差异
- git跟新gitbub的代码(首次跟新步骤)
- 判断手机是android还是ios,是否用了微信内置浏览器
- filebeat常见配置项梳理
- 数据丢失不用怕 iPhone手机数据备份方法分享
- 解决IE8固定宽度下拉列表中option内容显示不全问题
- python与mysql交互/读取本地配置文件/交互报错
- [高级软件工程实验]用可重用的链表模块来实现命令行菜单小程序V2.5
- 微积分之可微,可导,可积,连续之间的关系
- select函数及fd_set
- Battery Charging Specification 1.2 中文详解 USB
- win7使用putty报错已停止工作
- windows下安装的docker挂载window目录到docker容器
- xpath