HTML頁面跳轉的5種方法

下面列了五個例子來詳細說明,這幾個例子的主要功能是:在5秒後,自動跳轉到同目錄下的hello.html(根據自己需要自行修改)文件。
1) html的實現

  1. <head>   
  2. <!-- 以下方式只是刷新不跳轉到其他頁面 --> 
  3. <meta http-equiv="refresh" content="10">   
  4. <!-- 以下方式定時轉到其他頁面 --> 
  5. <meta http-equiv="refresh" content="5;url=hello.html">  
  6. </head> 

優點:簡單
缺點:Struts Tiles中無法使用

2) javascript的實現

  1. <script language="javascript" type="text/javascript">    
  2. // 以下方式直接跳轉   
  3. window.location.href='hello.html';   
  4. // 以下方式定時跳轉 
  5. setTimeout("javascript:location.href='hello.html'", 5000);  
  6. </script> 

優點:靈活,可以結合更多的其他功能
缺點:受到不同瀏覽器的影響
 

3) 結合了倒數的javascript實現(IE)

  1. <span id="totalSecond">5</span>   
  2. <script language="javascript" type="text/javascript">  
  3. var second = totalSecond.innerText;    
  4. setInterval("redirect()", 1000);    
  5. function redirect(){    
  6. totalSecond.innerText=--second;    
  7. if(second<0location.href='hello.html';    
  8. }    
  9. </script> 

優點:更人性化
缺點:firefox不支持(firefox不支持span、div等的innerText屬性)
 

3') 結合了倒數的javascript實現(firefox)

  1. <script language="javascript" type="text/javascript">  
  2. var second = document.getElementById('totalSecond').textContent;    
  3. setInterval("redirect()", 1000);    
  4. function redirect()    
  5. {    
  6. document.getElementById('totalSecond').textContent = --second;    
  7. if (second < 0location.href = 'hello.html';    
  8. }    
  9. </script> 

4) 解決Firefox不支持innerText的問題

 

  1. <span id="totalSecond">5</span>   
  2. <script language="javascript" type="text/javascript">   
  3. if(navigator.appName.indexOf("Explorer") > -1)
  4. {   
  5. document.getElementById('totalSecond').innerText = "my text innerText";   
  6. } else{   
  7. document.getElementById('totalSecond').textContent = "my text textContent";   
  8. }   
  9. </script> 

5) 整合3)和3')

 
  1. <span id="totalSecond">5</span>   
  2. <script language="javascript" type="text/javascript">   
  3. var second = document.getElementById('totalSecond').textContent;   
  4. if (navigator.appName.indexOf("Explorer") > -1) 
  5. {   
  6. second = document.getElementById('totalSecond').innerText;   
  7. } else {   
  8. second = document.getElementById('totalSecond').textContent;   
  9. }   
  10. setInterval("redirect()", 1000);   
  11. function redirect() {   
  12. if (second < 0) {   
  13. location.href = 'hello.html';   
  14. } else {   
  15. if (navigator.appName.indexOf("Explorer") > -1) {   
  16. document.getElementById('totalSecond').innerText = second--;   
  17. } else {   
  18. document.getElementById('totalSecond').textContent = second--;   
  19. }   
  20. }   
  21. }   
  22. </script> 

 

轉載自:http://www.cnblogs.com/aszx0413/articles/1886819.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章