婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > Html5頁面中的返回實(shí)現(xiàn)的方法

Html5頁面中的返回實(shí)現(xiàn)的方法

熱門標(biāo)簽:當(dāng)涂高德地圖標(biāo)注 電銷機(jī)器人電話用什么卡 成都智能外呼系統(tǒng)平臺(tái) 黃島區(qū)地圖標(biāo)注 四川點(diǎn)撥外呼系統(tǒng) 云南大理400電話申請官方 江蘇智能電銷機(jī)器人哪家好 鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 南寧點(diǎn)撥外呼系統(tǒng)哪家公司做的好

看到這個(gè)題目你可能覺得這是什么鬼? 其實(shí)我想說的是這種,看下面的錄制:

這種交互在H5頁面中比比皆是,點(diǎn)擊城市->彈出城市選擇浮層->按返回按鈕關(guān)閉浮層。

這些操作都是不要點(diǎn)擊左上角/右上角的關(guān)閉按鈕就可以進(jìn)行的,飛豬的H5是前進(jìn)出現(xiàn)彈層,返回時(shí)彈層關(guān)閉,其他家都不行(去哪兒網(wǎng)H5飛機(jī)票,美團(tuán)H5酒店)。

為什么要這么設(shè)計(jì)?

因?yàn)镠5是在手機(jī)上操作的,手機(jī)上的手指可操作區(qū)域的覆蓋范圍很小,更別說左上角/右上角這些死角(取消/關(guān)閉)區(qū)域了。你肯定聽過這個(gè)操作:輕觸返回。這個(gè)在用戶操作的時(shí)候非常方便友好,選擇完城市后,不需要點(diǎn)擊取消,直接在大拇指可以操作的地方點(diǎn)擊返回就關(guān)閉了彈層。

如何實(shí)現(xiàn)

既然有這種非常好的需求,那作為開發(fā)肯定就會(huì)想法設(shè)法的實(shí)現(xiàn)這個(gè)功能了。 你甚至都不用google,你就應(yīng)該會(huì)想到類似的history.back(),history.go()這些方法了。 然而想到這些依舊沒用,理論上 瀏覽器/webview 的返回/前進(jìn)的是要重新加載頁面的,因?yàn)閁RL發(fā)生了變化。 如果你真的知道單頁面應(yīng)用(SPA),或者使用React/Vue你就應(yīng)該知道有個(gè)東西叫:路由。 這些通過改變hash且無法刷新的url變化是HTML5時(shí)加入的history功能

the-history-interface

interface History {
  readonly attribute unsigned long length;
  attribute ScrollRestoration scrollRestoration;
  readonly attribute any state;
  void go(optional long delta = 0);
  void back();
  void forward();
  void pushState(any data, DOMString title, optional DOMString? url = null);
  void replaceState(any data, DOMString title, optional DOMString? url = null);
};
  1. pushState
  2. replaceState

還有一個(gè)事件

  1. onpopstate

pushState,replaceState 用來改變histroy堆棧順序,onpopstate 在返回,前進(jìn)的時(shí)候觸發(fā)

vue-router中的實(shí)現(xiàn)也是如此(第1694行)

具體實(shí)現(xiàn)

既然說了這么多,那我們來看下怎么實(shí)現(xiàn)這種功能。

來看下 pushState 和 replaceState 的兼容性

全綠,用起來放心多了。

思路:

  1. 點(diǎn)擊彈層時(shí) pushState 添加 hash
  2. "輕觸返回"的時(shí)候觸發(fā) onpopstate 事件時(shí)候隱藏彈層并修改 hash
<button onclick="city()">
        城市
    </button><br>
    <button onclick="calendar()">
        日歷
    </button><br>
    <button onclick="description()">
        說明
    </button>

    <div id="city" class="com" style="display: none;">
      模擬城市彈框?qū)?
    </div>
    <div id="calendar" class="com" style="display: none;">
      模擬日歷彈框?qū)?
    </div>
     <div id="description" class="com" style="display: none;">
      模擬說明彈框?qū)?
    </div>
      button {
          border: #0000;
          background-color: #f90;
      }
      .com {
        position: absolute ;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        background-color: #888589;
      }
var cityNode = document.getElementById('city');
    var calendarNode = document.getElementById('calendar');
    var descriptionNode = document.getElementById('description');
      function city() {
        cityNode.style.display = 'block';
        window.history.pushState({'id':'city'},'','#city')
      }
      function calendar() {
        calendarNode.style.display = 'block';
        window.history.pushState({'id':'calendar'},'','#calendar')
      }
      function description() {
        descriptionNode.style.display = 'block';
        window.history.pushState({'id':'description'},'','#description')
      }
      window.addEventListener('popstate', function(e){
        // alert('state:' + e.state + ', historyLength:' + history.length);
        if (e.state && e.state.id === 'city') {
            history.replaceState('','','#');
            cityNode.style.display = 'block';
        } else if (e.state && e.state.id === 'calendar') {
            history.replaceState('','','#');
            calendarNode.style.display = 'block';
        } else if (e.state && e.state.id === 'description') {
            history.replaceState('','','#');
            descriptionNode.style.display = 'block';
        } else {
            cityNode.style.display = 'none';
            calendarNode.style.display = 'none';
            descriptionNode.style.display = 'none';
        }
      })

主要看 JS 代碼,監(jiān)聽頁面的前進(jìn)和后退事件來控制history。

源碼在此

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:淮安 佳木斯 咸寧 廣西 南京 十堰 西寧 酒泉

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Html5頁面中的返回實(shí)現(xiàn)的方法》,本文關(guān)鍵詞  Html5,頁面,中的,返回,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Html5頁面中的返回實(shí)現(xiàn)的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Html5頁面中的返回實(shí)現(xiàn)的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 清河县| 策勒县| 项城市| 平塘县| 吴旗县| 卢湾区| 土默特右旗| 大荔县| 黄浦区| 泰和县| 长岛县| 扬州市| 宿迁市| 双城市| 淮滨县| 宝山区| 乌兰察布市| 伊川县| 保亭| 松潘县| 建湖县| 宣汉县| 新邵县| 彭山县| 富川| 津市市| 澄迈县| 赤水市| 遵义县| 黎平县| 仙游县| 泰顺县| 永登县| 山丹县| 岑溪市| 甘南县| 广水市| 怀柔区| 丹寨县| 扶绥县| 贵阳市|