JS全屏代碼詳解

一、JS代碼全稱

JS全屏代碼是指通過JavaScript實現網頁全屏化的一種技術。將HTML元素全屏顯示,常在需要功能強大的特效的網站中比較常用,比如視頻網站、圖片展示網站等等。

二、JS全屏事件

實現JS全屏的第一個步驟就是監聽全屏事件,基本語法如下:


    // 全屏事件。標準寫法 document.onfullscreenchange
    var changeEvent = function() {
      console.log("fullscreen", document.fullscreen);
      console.log("全屏狀態發生變化");
    };
    document.addEventListener("fullscreenchange", changeEvent, false);
    document.addEventListener("mozfullscreenchange", changeEvent, false);
    document.addEventListener("webkitfullscreenchange", changeEvent, false);
    document.addEventListener("MSFullscreenChange", changeEvent, false);

代碼解析:

使用addEventListener函數監聽全屏事件,監聽了四種事件:fullscreenchange、mozfullscreenchange、webkitfullscreenchange、MSFullscreenChange,分別對應不同瀏覽器。其中,changeEvent函數是回調函數,當監聽到事件時,系統會調用該函數。

三、JS代碼大全

下面給出JS全屏代碼,並且可以兼容 Chrome、Firefox、Safari、Opera、Edge 和 IE11 瀏覽器:


   function launchFullScreen(element) {
       if(element.requestFullscreen) {
           element.requestFullscreen();
       } else if(element.mozRequestFullScreen) {
           element.mozRequestFullScreen();
       } else if(element.webkitRequestFullscreen) {
           element.webkitRequestFullscreen();
       } else if(element.msRequestFullscreen) {
           element.msRequestFullscreen();
       }
   }
   function exitFullScreen() {
       if(document.exitFullscreen) {
           document.exitFullscreen();
       } else if(document.mozCancelFullScreen) {
           document.mozCancelFullScreen();
       } else if(document.webkitExitFullscreen) {
           document.webkitExitFullscreen();
       } else if(document.msExitFullscreen) {
           document.msExitFullscreen();
       }
   }

代碼解析:

launchFullScreen函數是將指定元素(element)全屏顯示的函數;exitFullScreen函數是退出全屏顯示的函數。

四、JS全屏滾動

在全屏顯示的時候,我們也經常需要全屏滾動的功能,以下給出滾動的基本代碼:


  // 在element中,滑動時觸發以下函數
  element.ontouchmove = function(event) {
    event.preventDefault();
  };
  // 滾輪滾動控制函數,兼容多瀏覽器
  window.addEventListener("mousewheel", scrollFunc, false);
  window.addEventListener("DOMMouseScroll", scrollFunc, false);
  function scrollFunc(e) {
    e = e || window.event;
    if (e.wheelDelta) {
      //ie/chrome
      if (e.wheelDelta > 0) {
        document.title = "向上滾";
        element.scrollTop -= 30;
      } else if (e.wheelDelta  0) {
        document.title = "向下滾";
        element.scrollTop += 30;
      } else if (e.detail < 0) {
        document.title = "向上滾";
        element.scrollTop -= 30;
      }
    }
  }

代碼解析:

在移動端,我們需要監聽用戶滾動操作,用element.ontouchmove函數來實現。在PC端,我們則要通過addEventListener監聽DOMMouseScroll、mousewheel事件,分別代表Firefox和IE/Chrome瀏覽器的瀏覽器滾輪事件。然後通過判斷瀏覽器類型調用scrollFunc函數,實現滾輪滾動的效果。

五、JS自動全屏

有時我們需要在頁面中自動全屏,以下代碼實現了自動全屏:


    // 開啟自動全屏
    var autoFull = function(eleme) {
      var ua = window.navigator.userAgent.toLowerCase(),
        docElm = doc.documentElement,
        i,
        ch,
        sc,
        si;
      eleme.onclick = function() {
        // 判斷瀏覽器類別,調用不同函數
        if (/chrome\/(\d{2})/i.test(ua)) {
          sc = document.documentElement.scrollTop;
          eleme.requestFullscreen();
          window.setTimeout(function() {
            document.documentElement.scrollTop = document.body.scrollTop = sc;
          }, 200);
        } else if (/firefox\/(\d{2})/i.test(ua)) {
          si = docElm.scrollTop;
          eleme.requestFullscreen();
          window.setTimeout(function() {
            docElm.scrollTop = si;
          }, 200);
        } else {
          ch = document.documentElement.clientHeight;
          i = document.documentElement.scrollTop || document.body.scrollTop;
          eleme.requestFullscreen();
          window.setTimeout(function() {
            document.documentElement.scrollTop = document.body.scrollTop = (i * document.documentElement.clientHeight) / ch;
          }, 200);
        }
      };
    };

代碼解析:

autoFull函數實現了自動全屏,其中包含判斷瀏覽器類別,調用不同函數的功能。chrome瀏覽器需要記錄滾動條位置,Firefox需要記錄文檔流位置,其他瀏覽器需要記錄文檔位置和瀏覽器高度進行換算。

六、JS瀏覽器全屏

對於一些不需要全屏顯示內容的網站,我們也可以實現瀏覽器全屏的效果,以下代碼實現了瀏覽器全屏:


    var fullScreen = function(el) {
      if (el.requestFullscreen) {
        el.requestFullscreen();
      } else if (el.msRequestFullscreen) {
        el.msRequestFullscreen();
      } else if (el.mozRequestFullScreen) {
        el.mozRequestFullScreen();
      } else if (el.webkitRequestFullScreen) {
        el.webkitRequestFullScreen();
      } else {
        alert("Sorry,您的瀏覽器不能全屏瀏覽!");
      }
    };

代碼解析:

fullScreen函數實現了瀏覽器全屏的效果,同樣兼容不同的瀏覽器類型。

七、JS頁面全屏

在一些特殊情況下,我們需要實現整個網頁的全屏,這時候需要進行以下操作:


  function launchFullscreen(element) {
    if (element.requestFullscreen) {
      element.requestFullscreen();
    } else if (element.mozRequestFullScreen) {
      element.mozRequestFullScreen();
    } else if (element.msRequestFullscreen) {
      element.msRequestFullscreen();
    } else if (element.webkitRequestFullscreen) {
      element.webkitRequestFullscreen(Element.ALLOW_KEYBOARD_INPUT);
    }
    // 添加Evnet Listener
    element.addEventListener("webkitfullscreenchange", function() {
      element.webkitRequestFullScreen();
    });
    element.addEventListener("fullscreenchange", function() {
      element.requestFullscreen();
    });
    element.addEventListener("mozfullscreenchange", function() {
      element.mozRequestFullScreen();
    });
    element.addEventListener("MSFullscreenChange", function() {
      element.msRequestFullscreen();
    });
  }

代碼解析:

launchFullscreen函數實現了整個網頁的全屏顯示,兼容性也比較好,但是需要添加webkitfullscreenchange、fullscreenchange、mozfullscreenchange、MSFullscreenChange這幾個事件,否則在全屏模式下某些瀏覽器會出現全屏不完全、全屏退出異常等問題。

八、JS瀏覽器自動全屏

以下代碼實現了瀏覽器自動全屏:


   function browserFullScreen() {
       var el = document.documentElement,
           rfs =
           el.requestFullScreen ||
           el.webkitRequestFullScreen ||
           el.mozRequestFullScreen ||
           el.msRequestFullscreen;
       if (typeof rfs != "undefined" && rfs) {
           rfs.call(el);
       }
   }

代碼解析:

browserFullScreen函數實現了瀏覽器自動全屏,只需調用該函數就可以實現自動全屏。

九、JS監聽全屏事件

以下代碼給出了監聽全屏事件的用例:


   document.addEventListener(
      "fullscreenchange",
      function(e) {
         console.log("全屏change事件", JSON.stringify(e));
      },
      false
   );

代碼解析:

addEventListener函數監聽了fullscreenchange事件,該事件的觸發表示瀏覽器的全屏狀態發生了改變,其回調函數console.log輸出了監聽到的全屏change事件,並把事件信息轉換為字元串。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/245086.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:05
下一篇 2024-12-12 13:05

相關推薦

  • JS Proxy(array)用法介紹

    JS Proxy(array)可以說是ES6中非常重要的一個特性,它可以代理一個數組,監聽數據變化並進行攔截、處理。在實際開發中,使用Proxy(array)可以方便地實現數據的監…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python字元串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字元串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字元串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • Python基礎代碼用法介紹

    本文將從多個方面對Python基礎代碼進行解析和詳細闡述,力求讓讀者深刻理解Python基礎代碼。通過本文的學習,相信大家對Python的學習和應用會更加輕鬆和高效。 一、變數和數…

    編程 2025-04-29
  • 倉庫管理系統代碼設計Python

    這篇文章將詳細探討如何設計一個基於Python的倉庫管理系統。 一、基本需求 在著手設計之前,我們首先需要確定倉庫管理系統的基本需求。 我們可以將需求分為以下幾個方面: 1、庫存管…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • 寫代碼新手教程

    本文將從語言選擇、學習方法、編碼規範以及常見問題解答等多個方面,為編程新手提供實用、簡明的教程。 一、語言選擇 作為編程新手,選擇一門編程語言是很關鍵的一步。以下是幾個有代表性的編…

    編程 2025-04-29
  • Python實現簡易心形代碼

    在這個文章中,我們將會介紹如何用Python語言編寫一個非常簡單的代碼來生成一個心形圖案。我們將會從安裝Python開始介紹,逐步深入了解如何實現這一任務。 一、安裝Python …

    編程 2025-04-29
  • 怎麼寫不影響Python運行的長段代碼

    在Python編程的過程中,我們不可避免地需要編寫一些長段代碼,包括函數、類、複雜的控制語句等等。在編寫這些代碼時,我們需要考慮代碼可讀性、易用性以及對Python運行性能的影響。…

    編程 2025-04-29
  • 北化教務管理系統介紹及開發代碼示例

    本文將從多個方面對北化教務管理系統進行介紹及開發代碼示例,幫助開發者更好地理解和應用該系統。 一、項目介紹 北化教務管理系統是一款針對高校學生和教職工的綜合信息管理系統。系統實現的…

    編程 2025-04-29

發表回復

登錄後才能評論