首頁 >web前端 >js教程 >js頁面刷新之實現普通頁面

js頁面刷新之實現普通頁面

高洛峰
高洛峰原創
2016-10-12 11:24:101047瀏覽

準備面試題目的時候遇到了頁面刷新,就整理了一下,網上查找,大概就是八種方法,但是自己測試的時候出現了幾個問題,跟大家分享:

首先準備一個測試頁面:

<!--html代码--> 
<h1 id="test">页面刷新</h1>
<button onclick="fresh()">刷新</button
//script
var h1 = document.getElementById(&#39;test&#39;);
function test(){
     h1.style.color = "red";
     h1.innerText = "我变化了";
}
setInterval(test, 1000);

準備工作完成,開始頁面刷新方法:

  1. 可以正常使用的五種方法:

 //第一种方法
function fresh(){
       window.location.reload();//强迫浏览器刷新当前页面,默认参数为false,表示从客户端缓存里取当前页。如果指定为true,则以GET方式从服务端取最新的页面,相当于客户端点击F5。
}
 //第二种方法
 function fresh(){
      history.go(0);
}
 //第三种方法
 function fresh(){
       location = location;
 }
 //第四种方法
 function fresh(){
       location.assign(location);//assign()方法加载一个新的文档。
 }
 //第五种方法
 function fresh(){
     location.replace(location);//通过指定URL替换当前缓存在历史里(客户端)的项目,所以使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL。
 }

2.只在ie可以執行的兩種方法:

 //第六种方法
 function fresh(){
       document.execCommand(&#39;Refresh&#39;);//是只有IE提供的方法,叫浏览器方法。
 }
 //第七种方法
 function fresh(){
       window.navigate(location);//只在ie可以执行,不适用于火狐等其他浏览器。
 }
 //错误方法
 function fresh(){
       document.URL=location.href;//错误用法,document.URL只能读不能写
 }

2.只在ie可以執行的兩種方法:

//第八种方法
//window.location.href和document.location.href可以被赋值,然后跳转到其它页面
//一个窗口下只有一个window.location.href,但是可能有多个document.URL、document.location.href
function fresh(){
      document.location.href = location.href;
      //可以使用,document表示的是一个文档对象   
}
 //第九种方法(与第八种方法是一类)
 function fresh(){
      window.location.href = location.href;//可以使用,window表示的是一个窗口对象
 }
個人認為是錯誤的一種方法:

rrreee

但也可以有替代的方法:

rrreeerrreee

🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn