<!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 none_b2(){
document.getElementById("b2").style.display="none";
}
function block_b2(){
document.getElementById("b2").style.display="block";
/* document.getElementById("b2").style.float="left"; */
}</script>
</head><body>
<img src="images/book1.jpg" alt="book1" id="b1" />
<img src="images/book2.jpg" alt="book2" id="b2" />
<img src="images/book3.jpg" alt="book3" id="b3" />
<br/> <input name="btn2" type="button" value="display隐藏图片b2" onclick="none_b2()" />
<input name="btn4" type="button" value="display显示图片b2" onclick="block_b2()" /></body>
</html>初学js,遇到这个问题 ,有三个图片book1,book2,book3并排放在页面上。
点击“display隐藏图片b2”这个按钮时,book2图片实现隐藏,book3占据book2的位置
现在想要实现点击"display显示图片b2"这个按钮时,图片book2显示出来,并且要恢复book2之前所在的位置,也就是说book3要后退一个位置,空出来的位置显示book2需要实现如示列图所示:初始位置
Book1 Book2 Book3点击“display隐藏图片b2”这个按钮后
Book1 Book3点击"display显示图片b2"这个按钮后,显示
Book1 Book2 Book3但是按上面的脚本运行的话
初始位置和点击“display隐藏图片b2”这个按钮后显示的都是一样的。
点击"display显示图片b2"这个按钮后,显示
Book1
Book2
Book3分了三行显示了如果在block_b2中,加入document.getElementById("b2").style.float="left";这行代码,则显示的时候,虽然book2可以跟book1,book3显示在同一行,但是boo2会出现在首位。这个javascript代码要怎么改呀。别让我重新加载页面呀
<!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 none_b2(){
document.getElementById("b2").style.display="none";
}
function block_b2(){
document.getElementById("b2").style.display="inline";
/* document.getElementById("b2").style.float="left"; */
}</script>
</head><body>
<img src="images/book1.jpg" alt="book1" id="b1" />
<img src="images/book2.jpg" alt="book2" id="b2" />
<img src="images/book3.jpg" alt="book3" id="b3" />
<br/> <input name="btn2" type="button" value="display隐藏图片b2" onclick="none_b2()" />
<input name="btn4" type="button" value="display显示图片b2" onclick="block_b2()" /></body>
</html>display: block 是以块状显示,所以就换行了,换成 inline,内联显示
LZ,你这里写错了: function block_b2(){
document.getElementById("b2").style.display="block";
/* document.getElementById("b2").style.float="left"; */
}应该改成 : function block_b2(){
document.getElementById("b2").style.visibility="hidden";
/* document.getElementById("b2").style.float="left"; */
}
对,1楼说的对,display属性的block是块状元素,此元素前后带换行符。
换行符这个词用的有点问题,不过意思我相信是没理解错~块级元素和内联元素都是布局的一些基础。有必要理清。另外类似的还有
padding与margin
display与visible等。