ES6 - การเปลี่ยนเส้นทางหน้า

Redirectเป็นวิธีส่งทั้งผู้ใช้และเครื่องมือค้นหาไปยัง URL ที่แตกต่างจากที่ขอไว้ในตอนแรก การเปลี่ยนเส้นทางหน้าเป็นวิธีเปลี่ยนเส้นทางหน้าเว็บไปยังหน้าเว็บอื่นโดยอัตโนมัติ หน้าที่เปลี่ยนเส้นทางมักจะอยู่บนเว็บไซต์เดียวกันหรืออาจอยู่บนเว็บไซต์อื่นหรือเว็บเซิร์ฟเวอร์ก็ได้

การเปลี่ยนเส้นทางหน้า JavaScript

window.location and window.location.href

ใน JavaScript คุณสามารถใช้หลายวิธีในการเปลี่ยนเส้นทางหน้าเว็บไปยังอีกหน้าหนึ่ง เกือบทุกวิธีเกี่ยวข้องกับwindow.locationวัตถุซึ่งเป็นคุณสมบัติของวัตถุ Window สามารถใช้เพื่อรับที่อยู่ URL ปัจจุบัน (ที่อยู่เว็บ) และเปลี่ยนเส้นทางเบราว์เซอร์ไปยังหน้าใหม่ ประเพณีทั้งสองเหมือนกันในแง่ของพฤติกรรมwindow.locationส่งคืนวัตถุ ถ้า.href ไม่ได้ตั้งค่า window.location ค่าเริ่มต้นในการเปลี่ยนพารามิเตอร์ .href.

ตัวอย่าง

<!DOCTYPE html> 
<html> 
   <head> 
      <script> 
         function newLocation() { 
            window.location = "http://www.xyz.com"; 
         } 
      </script> 
   </head> 

   <body> 
      <input type = "button" value = "Go to new location" onclick = "newLocation()"> 
   </body> 
</html>

location.replace()

อีกวิธีหนึ่งที่ใช้บ่อยที่สุดคือ replace()วิธีการของวัตถุ window.location มันจะแทนที่เอกสารปัจจุบันด้วยเอกสารใหม่ ในวิธีการแทนที่ () คุณสามารถส่ง URL ใหม่เพื่อแทนที่ () วิธีการและจะดำเนินการเปลี่ยนเส้นทาง HTTP

ต่อไปนี้เป็นไวยากรณ์สำหรับสิ่งเดียวกัน

window.location.replace("http://www.abc.com

location.assign()

location.assign () วิธีการโหลดเอกสารใหม่ในหน้าต่างเบราว์เซอร์

ต่อไปนี้เป็นไวยากรณ์สำหรับสิ่งเดียวกัน

window.location.assign("http://www.abc.org");

assign() vs. replace()

ความแตกต่างระหว่างวิธีการกำหนด () และแทนที่ () คือเมธอด location.replace () จะลบ URL ปัจจุบันออกจากประวัติเอกสารดังนั้นจึงไม่สามารถย้อนกลับไปยังเอกสารต้นฉบับได้ คุณไม่สามารถใช้ปุ่ม "ย้อนกลับ" ของเบราว์เซอร์ในกรณีนี้ หากคุณต้องการหลีกเลี่ยงสถานการณ์นี้คุณควรใช้เมธอด location.assign () เนื่องจากจะโหลดเอกสารใหม่ในเบราว์เซอร์

location.reload()

เมธอด location.reload () จะโหลดเอกสารปัจจุบันซ้ำในหน้าต่างเบราว์เซอร์

ต่อไปนี้เป็นไวยากรณ์สำหรับสิ่งเดียวกัน

window.location.reload("http://www.yahoo.com");

window.navigate()

window.navigate () วิธีการคล้ายกับการกำหนดค่าใหม่ให้กับคุณสมบัติ window.location.href เนื่องจากมีเฉพาะใน MS Internet Explorer ดังนั้นคุณควรหลีกเลี่ยงการใช้สิ่งนี้ในการพัฒนาข้ามเบราว์เซอร์

ต่อไปนี้เป็นไวยากรณ์สำหรับสิ่งเดียวกัน

window.navigate("http://www.abc.com");

การเปลี่ยนเส้นทางและการเพิ่มประสิทธิภาพกลไกค้นหา

หากคุณต้องการแจ้งให้เครื่องมือค้นหา (SEO) ทราบเกี่ยวกับการส่งต่อ URL ของคุณคุณควรเพิ่มเมตาแท็ก rel = "canonical" ในส่วนหัวของเว็บไซต์ของคุณเนื่องจากเครื่องมือค้นหาไม่ได้วิเคราะห์ JavaScript เพื่อตรวจสอบการเปลี่ยนเส้นทาง

ต่อไปนี้เป็นไวยากรณ์สำหรับสิ่งเดียวกัน

<link rel = "canonical" href = "http://abc.com/" />