为什么 jquery fadeIn()不能与. html()一起工作?

当你点击一个复选框,我希望消息慢慢淡出。

为什么. fadeIn ()在这个示例中不起作用?

HTML:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"/>
<title>Text XHTML Page</title>
<link href="css/main.css" rel="stylesheet" type="text/css" media="all"/>
<script type="text/javascript" src="http://www.google.com/jsapi"></script>
<script type="text/javascript" src="javascript/main.js"></script>
</head>
<body>
<div class="checkboxList">
<div class="title">Languages:</div>
<div class="row"><input class="checkbox" type="checkbox"/><span class="label">Ruby</span></div>
<div class="row"><input type="checkbox"/><span class="label">PHP</span></div>
<div class="row"><input type="checkbox"/><span class="label">C#</span></div>
<div class="row"><input type="checkbox"/><span class="label">Python</span></div>
<div class="row"><input type="checkbox"/><span class="label">JavaScript</span></div>
</div>
<p id="message"></p>
</body>
</html>

Javascript:

google.load("jquery", "1.3.2");


//run when page is loaded
google.setOnLoadCallback(function() {


$('.checkboxList .row').css('color','red');
$('.checkboxList input').attr('checked', true);
$('.checkboxList input').bind('click', function() {
$('#message').html("You clicked on a checkbox.").fadeIn('slow');
});


});
69643 次浏览

不知道为什么,不过我以前也有过这样的经历。您可以通过使用这个不那么优雅的代码来获得您想要的效果:

google.load("jquery", "1.3.2");


//run when page is loaded
google.setOnLoadCallback(function() {


$('.checkboxList .row').css('color','red');
$('.checkboxList input').attr('checked', true);
$('.checkboxList input').bind('click', function() {
$('#message').hide(); //just in case
$('#message').html("You clicked on a checkbox.");
$('#message').fadeIn('slow');
});


});

没有做 fadeIn,因为 # message 元素是可见的,隐藏它,添加内容和淡入:

$('#message').hide().html("You clicked on a checkbox.").fadeIn('slow');

在分析了这个问题之后,我必须解决这个问题,这是我的代码,可以使用淡出,改变 html 和淡出

$("#div_big_picture").fadeOut('slow',function(){
$(this).html("<img src='" + str_to_load + "' height='800px' />")
}).fadeIn("slow");