jQuery : IE6의 창 컨트롤 문제
-
05-07-2019 - |
문제
선택 상자가 포함 된 웹 페이지가 있습니다. jQuery 대화 상자를 열면 일부 상자 뒤에 부분적으로 표시됩니다.
이 문제에 어떻게 접근해야합니까? 선택 상자를 숨기거나 jQuery가 일종의 '심'솔루션을 제공해야합니다. (Googled가 있었지만 아무것도 찾지 못했습니다)
다음은 몇 가지 코드입니다.
<!DOCTYPE html>
<html lang="en">
<head>
<title>testJQuery</title>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<meta name="GENERATOR" content="Rational Application Developer">
<link rel="stylesheet" href="theme/smooth/theme.css" type="text/css" media="screen" />
</head>
<body>
<a class="pop" href="nix">Click me</a>
<p/>
<select size="20">
<option>s jl fjlkdjfldjf l*s ldkjsdlfkjsdl fkdjlfks dfldkfjdfkjlsdkf jdksdjf sd</option>
<option>s jl fjlkdjfldjf l*s ldkjsdlfkjsdl fkdjlfks dfldkfjdfkjlsdkf jdksdjf sd</option>
<option>s jl fjlkdjfldjf l*s ldkjsdlfkjsdl fkdjlfks dfldkfjdfkjlsdkf jdksdjf sd</option>
<option>s jl fjlkdjfldjf l*s ldkjsdlfkjsdl fkdjlfks dfldkfjdfkjlsdkf jdksdjf sd</option>
<option>s jl fjlkdjfldjf l*s ldkjsdlfkjsdl fkdjlfks dfldkfjdfkjlsdkf jdksdjf sd</option>
</select>
<div id="xyz" class="flora hiddenAsset">
<div id="dialog" title="Edit Link">
<p>Enter the link details:</p>
<table width="80%" border="1">
<tr><td>URL</td><td><input id="url" style="width:100%" maxlength="200" value="{url}"/></td></tr>
<tr><td>Title</td><td><input id="title" style="width:100%" maxlength="200" value="{title}"/></td></tr>
<tr><td>Target</td><td><input id="target" size="20" maxlength="200" value="{target}"/></td></tr>
</table>
</div>
</div>
<script type="text/javascript" src="../script/firebug/firebug.js"></script>
<script type="text/javascript" src="jquery-1.2.6.js"></script>
<script type="text/javascript" src="jquery-ui-1.5.2.js"></script>
<script type="text/javascript" src="jqSOAPClient.js"></script>
<script type="text/javascript">
(function($){
$(document).ready(function(){
console.debug('ready');
$('.hiddenAsset').hide();
$('a.pop').bind('click', showDialog);
console.debug('ready - done');
});
var showDialog = function(){
console.debug('show');
$('#dialog').dialog({
modal: true,
overlay: {
backgroundColor: '#666',
opacity: '.3',
filter: 'alpha(opacity=30)'
},
width: '400px',
height: '300px',
buttons: {
Ok: function() {
$(this).dialog('close');
},
Cancel: function() {
$(this).dialog('close');
}
}
});
console.debug('show-done');
return false;
};
})(jQuery);
</script>
</body>
</html>
해결책
이것은 특히 jQuery와 관련이 없습니다. 이것은 IE 6에서 알려진 버그입니다. 당신이 할 수있는 유일한 일은 그것을 덮을 때 선택된 상자를 숨기는 것입니다. 일반적으로 선택 상자처럼 보이는 것으로 교체하는 것입니다.
다른 팁
결국 도움이되는 플러그인을 찾았습니다. bgiframe 플러그인으로 사용할 수 있다는 것이 이상합니다. 왜 메인 UI에 통합되지 않습니까?!
시도해 보았지만 불행히도 내 대화를 망쳐 놓습니다! 대화 상자 내용은 모두 30-40 픽셀로 남겨져 있습니다 :-(. 다음 문제 ...
제휴하지 않습니다 StackOverflow