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/" />