欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實現前端路由功能示例【原生路由】

 更新時間:2020年05月29日 10:06:03   作者:TANKING  
這篇文章主要介紹了JS實現前端路由功能,結合實例形式分析了js實現原生路由的相關原理與操作技巧,需要的朋友可以參考下

本文實例講述了JS實現前端路由功能。分享給大家供大家參考,具體如下:

路由就是根據不同的 url 地址展示不同的內容或頁面,早期路由的概念是在后端出現的,通過服務器端渲染后返回頁面,隨著頁面越來越復雜,服務器端壓力越來越大。后來ajax異步刷新的出現使得前端也可以對url進行管理,此時,前端路由就出現了。

單頁面就是有前端路由來實現的,也就是說網站只有一個頁面,點擊導航會顯示不同的內容,對應的url也在發(fā)生改變。在這個過程中,js會實時檢測url的變化,從而改變顯示的內容。

路由實現的原理:window綁定了監(jiān)聽函數,當url的hash值發(fā)生變化的時候會觸發(fā)hashchange回調,在回調中進行不同的操作,馬上刷新頁面,從而顯示不同的頁面。

下面是一個前端路由的簡單實現:通過路由實現url的切換、頁面內容的改變。

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>前端路由測試</title>
  <script src="https://www.jq22.com/jquery/jquery-3.3.1.js"></script>
 
  <style>
      *{
        margin:0;
        padding: 0;
      }

      .content{
        width: 500px;
        height: 300px;
        margin-top: 30px;
        margin:20px auto 0;
      }

      #click_btn{
        width: 500px;
        height: 50px;
        margin:100px auto 0;
      }

      #click_btn a{
        display: block;
        background: #333;
        color: #fff;
        text-decoration: none;
        line-height: 50px;
        text-align: center;
        float: left;
        margin-right: 15px;
        padding: 0px 15px;
      }

      #click_btn a:hover{
        background: #666;
      }
  </style>
 
</head>
<body>
<div id="click_btn">
  <a href="#/one" rel="external nofollow" >第一個頁面</a>
  <a href="#/two" rel="external nofollow" >第二個頁面</a>
  <a href="#/three" rel="external nofollow" >第三個頁面</a>
</div>

<div class="content"></div>
 
<script src="router.js"></script>
<script src="test.js"></script>
 
</body>
</html>

router.js

//構造函數
function Router() {
  this.routes = {};
  this.currentUrl = '';
}
Router.prototype.route = function(path, callback) {
  this.routes[path] = callback || function(){};//給不同的hash設置不同的回調函數
};
Router.prototype.refresh = function() {
  console.log(location.hash.slice(1));//獲取到相應的hash值
  this.currentUrl = location.hash.slice(1) || '/';//如果存在hash值則獲取到,否則設置hash值為/
  // console.log(this.currentUrl);
  if(this.currentUrl&&this.currentUrl!='/'){
    this.routes[this.currentUrl]();//根據當前的hash值來調用相對應的回調函數
  }
 
};
Router.prototype.init = function() {
  window.addEventListener('load', this.refresh.bind(this), false);
  window.addEventListener('hashchange', this.refresh.bind(this), false);
}
//給window對象掛載屬性
window.Router = new Router();
window.Router.init();

test.js

Router.route('/one', function () {
  $(".content").html("<p>路由就是根據不同的 url 地址展示不同的內容或頁面,早期路由的概念是在后端出現的,通過服務器端渲染后返回頁面,隨著頁面越來越復雜,服務器端壓力越來越大。后來ajax異步刷新的出現使得前端也可以對url進行管理,此時,前端路由就出現了。</p>");
});
Router.route('/two', function () {
  $(".content").html("<h3>單頁面就是有前端路由來實現的,也就是說網站只有一個頁面,點擊導航會顯示不同的內容,對應的url也在發(fā)生改變。在這個過程中,js會實時檢測url的變化,從而改變顯示的內容。</h3>");
});
Router.route('/three', function () {
  $(".content").html("<img src='https://upload-images.jianshu.io/upload_images/12890819-f8665293cc8d0dcf.png?imageMogr2/auto-orient/strip|imageView2/2/w/1200/format/webp' width='500'/>");
});

注意:router.js要在test.js之前進行調用,不然會先加載test.js從而找不到,出現router.js未被定義。

上面router對象實現主要提供了三個方法

1.init監(jiān)聽瀏覽器url的hash值更新事件。

2.route存儲路由更新時的回調到回調數組routes中,回掉函數將負責對頁面進行更新。

3.refresh執(zhí)行當前url的回調函數,更新頁面。

感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調試運行工具http://tools.jb51.net/code/WebCodeRun測試上述代碼運行效果。

更多關于JavaScript相關內容可查看本站專題:《JavaScript切換特效與技巧總結》、《JavaScript遍歷算法與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • js實現一個頁面多個倒計時的3種方法

    js實現一個頁面多個倒計時的3種方法

    這篇文章主要為大家詳細介紹了js實現一個頁面多個倒計時的3種方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • js閉包實現按秒計數

    js閉包實現按秒計數

    閉包是一個擁有許多變量和綁定了這些變量的環(huán)境的表達式(通常是一個函數),因而這些變量也是該表達式的一部分。相信很少有人能直接看懂這句話,因為他描述的太學術。其實這句話通俗的來說就是:JavaScript中所有的function都是一個閉包。
    2015-04-04
  • JS二叉樹的簡單實現方法示例

    JS二叉樹的簡單實現方法示例

    這篇文章主要介紹了JS二叉樹的簡單實現方法,結合具體實例形式分析了基于javascript定義二叉樹及二叉樹節(jié)點的遍歷、查找、添加、刪除及運算相關操作技巧,需要的朋友可以參考下
    2017-04-04
  • JavaScript實現從數組中選出和等于固定值的n個數

    JavaScript實現從數組中選出和等于固定值的n個數

    這篇文章主要介紹了JavaScript實現從數組中選出和等于固定值的n個數的方法,需要的朋友可以參考下
    2014-09-09
  • 解決canvas畫布使用fillRect()時高度出現雙倍效果的問題

    解決canvas畫布使用fillRect()時高度出現雙倍效果的問題

    下面小編就為大家?guī)硪黄鉀Qcanvas畫布使用fillRect()時高度出現雙倍效果的問題。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • 完美解決手機瀏覽器頂部下拉出現網頁源或刷新的問題

    完美解決手機瀏覽器頂部下拉出現網頁源或刷新的問題

    下面小編就為大家分享一篇完美解決手機瀏覽器頂部下拉出現網頁源或刷新的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • JavaScript布爾運算符原理使用解析

    JavaScript布爾運算符原理使用解析

    這篇文章主要介紹了JavaScript布爾運算符原理使用解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • 詳解JavaScript對象類型

    詳解JavaScript對象類型

    這篇文章主要為大家詳細介紹了JavaScript對象類型,分析了JavaScript六種數據類型,感興趣的小伙伴們可以參考一下
    2016-06-06
  • 學習drag and drop js實現代碼經典之作

    學習drag and drop js實現代碼經典之作

    今天讀John Resig的Pro Javascript Techniques時候看到他書上給的一個關于drag and drop的例子, 合上書本自己寫一個簡化版本的。大約20分鐘完成, 沒有考慮兼容firefox。整個代碼封裝成一個對象 也是借鑒書中的風格。我覺得很好。
    2009-04-04
  • JS實現的判斷方法、變量是否存在功能示例

    JS實現的判斷方法、變量是否存在功能示例

    這篇文章主要介紹了JS實現的判斷方法、變量是否存在功能,涉及javascript針對變量、方法判斷與異常處理操作技巧,需要的朋友可以參考下
    2018-05-05

最新評論