用原生js做單頁應用

来源:http://www.cnblogs.com/LuckyWinty/archive/2016/11/23/6090430.html
-Advertisement-
Play Games

最近在公司接到一個需求,裡面有一個三級跳轉。類似於選擇地址的時候,選擇的順序是:省份->市->區。如果分三個頁面跳轉,那麼體驗非常不好,如果引入其他框架做成單頁應用,又比較麻煩。所以可以用js把這一塊做成單頁應用的樣子。。。 主要思路 通過改變url的hash值,跳到相應模塊。先把預設模塊顯示出來, ...


最近在公司接到一個需求,裡面有一個三級跳轉。類似於選擇地址的時候,選擇的順序是:省份->市->區。如果分三個頁面跳轉,那麼體驗非常不好,如果引入其他框架做成單頁應用,又比較麻煩。所以可以用js把這一塊做成單頁應用的樣子。。。

 

主要思路

    通過改變url的hash值,跳到相應模塊。先把預設模塊顯示出來,其他模塊隱藏,分別給三個模塊定義三個hash值,點擊預設模塊的選項的時候,改變hash值,同時在window上監聽hashchange事件,並作相應模塊跳轉邏輯處理。這樣即可模擬瀏覽器的前進後退,而且用戶體驗也比較好。

下麵詳細來看看,現在有一個場景,選擇順序是:車牌子->車型->車系。

首先HTML部分。預設顯示車牌子選擇列表,其他兩個模塊隱藏。

  <div class="wrap">
    <div id="Brand">
      <div>品牌</div>
        <ul class="mycar_hot_list">
          <li>
            <p>大眾</p>
          </li>
        </ul>
      </div>
      <div id="Type"  style="display:none">
        <dl>
        <dt>比亞迪汽車</dt>
        <dd>宋</dd>
      </dl>
    </div>
    <div id="Series" style="display:none">
      <ul class="mycar_datalist">
         <li>
           2013年款
         <li>
      </ul>
    </div>
  </div>

js邏輯控制部分

①定義一個變數對象,存儲三個模塊中分別選擇的數據、定義hash值、相應模塊的處理邏輯函數。

   info={
            brand:'',
            carType:'',
            carSeries:'',
            pages:['Brand','Type','Series']  
        };
info.selectBrand=function(){
      document.title = '選擇商標'; 
      brandEvent();
}
//選擇車型
info.selectType=function(){
      document.title = '選擇車型';
      document.body.scrollTop = 0;  //滾到頂部
       window.scrollTo(0, 0); 
       typeEvent();  //為該模塊的dom綁定事件或做其他邏輯
}
//選擇車系
info.selectSeries=function(){
      document.title = '選擇車系';
      document.body.scrollTop = 0;
      window.scrollTo(0, 0); 
      seriesEvent();
}

②dom綁定事件&其他邏輯

      function brandEvent(){
    //綁定跳轉
       $('#Brand ul li').click(function(){
           info.brand=$(this).find('p').text();
           goPage('Type');
       })
      }
      function typeEvent(){
    //綁定跳轉
       $('#Type  dd').click(function(){
           info.carType=$(this).text();
           goPage('Series');
       })
      }
      function seriesEvent(){...}

③goPage邏輯跳轉控制

    function goPage(tag) {
        if ((tag == 'Brand')&&(location.hash.indexOf('Type')!=-1)){ // 後退操作
                history.back();
                document.title = '選擇商標';  
        }else if ((tag == 'Type')&&(location.hash.indexOf('Series')!=-1)){
                history.back();
                document.title = '選擇車型'; 
        }else {
            location.hash = tag;
        }
    }

④js入口文件(這裡用了zepto.js來選擇dom)

window.onload=function(){
        info.selectBrand();  //為預設顯示的模塊中的元素綁定相應的事件及其他邏輯
        $(window).on("hashchange", function (e) {
            doHashChange();
       });
}

⑤最重要的hash改變邏輯控制

    function doHashChange(){
        //獲取hash的值
        var hash = location.hash.split('|')[0],
            tag = hash.replace(/#/g, '');
        if (info.pages.indexOf(tag) == -1) {
            tag = 'Brand';
        }
        $('.wrap').children('div').hide();    
        //執行每個模塊不同的方法
        if(typeof(info['select' + tag]) == "function"){
            info['select' + tag]();
        }
        //展示對應dom
        $('#' + tag).show();
    }

 

 

想參考demo?

  本例沒有demo。。。^_^ 

  

  

  

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 面向對象之理解 1.簡單舉例: 我們可以看到一個超市有收銀員,採購員,配貨員等. 收銀員之間:有不同的姓名,年齡,工號等,但有相同的行為方法,即掃描貨物,收錢,找錢等. 採購員之間:有不同的姓名,年齡,工號等,但有相同的行為方法,即統計缺貨數量,進行採購行為等. 配貨員之間:有不同的姓名,年齡,工號 ...
  • 接上篇簡單工廠模式進行改進。 由於簡單工廠模式違背開-閉原則,彈性太弱,例如增加一種鳥類,會造成修改類(工廠類) 好的實現應該是增加一種鳥類不影響現有類的修改。 思路: 在簡單工廠的基礎上我們增加一個抽象類(基礎抽象類),並且在基礎抽象工廠類中必須要定義一個抽象方法用來獲取所有鳥類的抽象基類,然後使 ...
  • 1、實體Entites 1.1 概念 實體是DDD(領域驅動設計)的核心概念之一。 實體是具有唯一標識的ID且存儲在資料庫總。實體通常被映射成資料庫中的一個表。 在ABP中,實體繼承自Entity類。 Id是所有繼承自Entity類的實體主鍵。 Id數據類型可以被更改,預設是int(int32)類型 ...
  • 簡單工廠簡述: 簡單工廠模式實現了生產產品類的代碼跟客戶端代碼分離,在工廠類中你可以添加需要生成長跑的邏輯代碼(new 產品類),但是問題來了,優秀的代碼是符合“開閉原則”如果你要加一個C類產品,你就要修改工廠類裡面的代碼,也就是說要增加條件語句如:switch case。對於這個問題,接下來的工廠 ...
  • 我是最後端的,這兩天搞了一個app項目,前端安卓使用友盟很方便,調試比較順利,然後ios就遇到各種問題了,證書、發送成功推送不成功,測試時用的TestMode(),ios上架之後就必須用productionMode(),糾結了幾天,還是換成jpush,很快就調試成功了。 趁著中午休息的時間,兩個平臺 ...
  • 最近天氣變化無常,身為程式猿的寡人!~終究難耐天氣的挑戰,病倒了,果然,程式猿還需多保養自己的身體,有句話這麼說:一生只有兩件事能報複你:不夠努力的辜負和過度消耗身體的後患。話不多說,開始吧。 一、什麼是簡單工廠模式 簡單工廠 (Simple Factory)又稱靜態工廠方法模式(Static Fa ...
  • web前端開發者最最註的內容是三個:HTML、CSS與JavaScript,他們分別在不同方面發揮自己的作用,HTML實現頁面結構,CSS完成頁面的表現與風格,JavaScript實現一些客戶端的功能與業務。當然內容與用戶資源也是不能忽視的。儘量不要跨職責範圍使用,有點“SRP單一職責”的意思,如字 ...
  • ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...