使用CSS在Jquery UI对话框中创建元素......如何?
题
由于旧版本显然太难以让人们理解,因此这里结合了HTML,CSS和JavaScript:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<title>test title</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.7.2/jquery-ui.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$('#test').dialog({ autoOpen: false, modal: true });
$("#test-link").click( function() {
$('#test').dialog('open');
});
});
</script>
<style type="text/css">
div#main div#test label {
display: block;
}
div#main div#test input {
padding-left: 100px;
}
</style>
</head>
<body>
<div id="main">
<p><a href="#" id="test-link">test</a><p>
<div id="test" title="Submit Bug or Feature Request">
<form>
<label for="test_desc">Short Description:</label>
<input type="text" name="test_desc" id="test_desc" value="" />
<input type="submit" name="" value="Submit" />
</form>
</div>
</div>
</body>
</html>
对话框工作正常,但CSS没有。有什么想法吗?
解决方案
JQuery在DOM树中移动对话框的DIV并将其包装在其他一些树中。因此CSS选择器将无法工作。使用上面的例子,你必须做这样的事情:
div.ui-dialog div#test label {
display: block;
}
div.ui-dialog div#test input {
padding-left: 100px;
}
其他提示
css应该有效。这可能是css规则如何级联的问题。是否有更具体的选择器应用这些规则,如“#dialog div #test label”?没有html / css的其余部分,就无法指出具体细节。获取firebug,看看哪些规则适用于这些元素。
不隶属于 StackOverflow