js中style.display=

  本文实例讲述了js中style.display=""无效的解决方法。分享给大家供大家参考。具体解决方法如下:

  一、问题描述:

  在js中我们有时想动态的控制一个div显示或隐藏或更多的操作,但如果我们style.display=""可能导致没有效果。

  看下面一段代码:

  

复制代码 代码如下:
<style>

  #name

  {

  display:none;

  }

  </style>

  </head>

  <body>

  <div id="name" >

  My name is smile.

  </div>

  </body>

  </html>

  <script>

  window.onload=function(){

  document.getElementById('name').style.display="";

  alert("test");

  }

  </script>

  css定义了id为name的div为隐藏,而我们在页面加载完成之后用js控制该id显示出来,这样写有错么?

  木有错?可是为什么界面上还是空白呢?

  二、解决方法:

  记得还有一个用法是xxx.style.display="block" 那我们试试吧,

  呜呼,竟然显示了!!!

  那我们查看一下style.display=""和style.display="block"用法有什么不同吧。

  其实,这两个的最大区别是block是块显示的,所以会换行,那么既然就这么点区别,为什么在本例子中一个可以显示,一个不行呢?困扰。

  好吧,这个问题先放开,我们先看现在这个问题中我们如何解决,除了用style.display="block"可以解决外,还有另外一种办法就是:

  

复制代码 代码如下:
<div id="name" style="display:none" >

  My name is smile.

  </div>

  <script>

  document.getElementById('name').style.display="";

  </script>

  就是把id为name的样式用style这样内置到标签内,这样不管用display=""还是display="block"就都可以正常显示啦!

  希望本文所述对大家基于javascript的web程序设计有所帮助。