」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 是否有跨瀏覽器的 JavaScript 取代 CSS 視窗單元(vh 和 vw)?

是否有跨瀏覽器的 JavaScript 取代 CSS 視窗單元(vh 和 vw)?

發佈於2024-11-15
瀏覽:898

Is there a cross-browser JavaScript alternative to CSS viewport units (vh and vw)?

使用JavaScript 的CSS 視口單位

CSS3 引入了視口百分比長度單位vh 和vw,這對於響應式佈局非常有價值。然而,問題是這些單元是否存在跨瀏覽器 JavaScript 替代方案。

JavaScript/jQuery 替代方案

當然!可以利用 jQuery 為視口單元提供替代方案。這是一個基於 jQuery 的解決方案:

/* jQuery plugin to convert viewport units to pixels */
;(function( $, window ){

  var $win = $(window)
    , _css = $.fn.css;

  function viewportToPixel( val ) {
    var percent = val.match(/[\d.] /)[0] / 100
      , unit = val.match(/[vwh] /)[0];
    return (unit == 'vh' ? $win.height() : $win.width()) * percent  'px';
  }

  function parseProps( props ) {
    var p, prop;
    for ( p in props ) {
      prop = props[ p ];
      if ( /[vwh]$/.test( prop ) ) {
        props[ p ] = viewportToPixel( prop );
      }
    }
    return props;
  }

  $.fn.css = function( props ) {
    var self = this
      , originalArguments = arguments
      , update = function() {
          if ( typeof props === 'string' || props instanceof String ) {
            if (originalArguments.length > 1) {
              var argumentsObject = {};
              argumentsObject[originalArguments[0]] = originalArguments[1];
              return _css.call(self, parseProps($.extend({}, argumentsObject)));
            } else {
              return _css.call( self, props );
            }
          } else {
            return _css.call( self, parseProps( $.extend( {}, props ) ) );
          }
        };
    $win.resize( update ).resize();
    return update();
  };

}( jQuery, window ));

**Usage:**

$('div').css({
高度: '50vh',
寬度: '50vw',
marginTop: '25vh',
marginLeft: '25vw ',
字體大小: '10vw'
});

This solution seamlessly integrates the viewport unit conversion into jQuery's CSS method, allowing for easy resizing of elements based on viewport dimensions.

**Safety Considerations**
最新教學 更多>
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-15
  • 顯示未知數量的卡片時如何防止 Flex 項目重疊?
    顯示未知數量的卡片時如何防止 Flex 項目重疊?
    重疊 Flex 項目問題水平顯示一組未知數量的撲克牌,如果它們超過一定寬度,可能會導致它們重疊。 Flex 框可以用於此目的,但控制大小和重疊可能很棘手。 解決方案此解決方案涉及設定特定的 CSS 屬性以實現所需的效果。細分如下:Container:.cards 容器使用 flexbox (disp...
    程式設計 發佈於2024-11-15
  • uint8_t 總是等於 unsigned char 嗎?
    uint8_t 總是等於 unsigned char 嗎?
    對uint8_t 和unsigned char 等價性的調查C 和C 領域中uint8_t 和unsigned char 之間的相互作用提出了有關它們的問題可能出現的分歧。特別是,當 CHAR_BIT 超過 8 時,就會出現問題,導致 uint8_t 無法封裝在 8 位元內。 定義 uint8_t ...
    程式設計 發佈於2024-11-15
  • 建立 Redis 克隆:深入研究內存資料存儲
    建立 Redis 克隆:深入研究內存資料存儲
    在資料儲存解決方案領域,Redis 作為強大的記憶體鍵值儲存脫穎而出。憑藉其高性能和多功能性,它已成為許多開發人員的首選。在這篇文章中,我將引導您從頭開始建立 Redis 克隆的過程,分享見解、挑戰以及我在過程中所做的設計選擇。 項目概況 該專案的目標是複製 Redis 的基本功能...
    程式設計 發佈於2024-11-15
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-15
  • 如何在 Python 中使用 Lambda 函數
    如何在 Python 中使用 Lambda 函數
    Python 中的 Lambda 函数是动态创建小型匿名函数的强大方法。这些函数通常用于简短的操作,其中不需要完整函数定义的开销。 传统函数是使用 def 关键字定义的,而 Lambda 函数是使用 lambda 关键字定义的,并且直接集成到代码行中。特别是,它们经常用作内置函数的参数。它们使开发人...
    程式設計 發佈於2024-11-15
  • Java 8 中 Stream.map() 和 Stream.flatMap() 之間的主要差異是什麼?
    Java 8 中 Stream.map() 和 Stream.flatMap() 之間的主要差異是什麼?
    Java 8 中的Stream.map() 與Stream.flatMap()Stream.map() 和Stream.flatMap()是Java 8 中兩種常用的方法,它們會對值流執行類似的轉換。然而,它們在處理和傳回值的方式上有根本的差異。 Stream.map()接受一個 Function
    程式設計 發佈於2024-11-15
  • 如何更改預設 Python 版本:為什麼我的終端機仍然使用 Python 2?
    如何更改預設 Python 版本:為什麼我的終端機仍然使用 Python 2?
    如何更改預設Python 版本:超越相容性問題您安裝了Python 3.2,儘管運行了Update Shell Profile 命令,終端終端終端機仍存在顯示Python 2.6.1。這種差異可能會令人困惑,所以讓我們探討一下如何更改預設的 Python 版本。 歷史背景:向後相容性和多個版本過去,...
    程式設計 發佈於2024-11-15
  • 負文字縮排是從無序列表中刪除縮排的唯一方法嗎?
    負文字縮排是從無序列表中刪除縮排的唯一方法嗎?
    從無序列表中刪除縮排:負文字縮排是唯一的解決方案嗎? 問題出現了:如何消除無序列表中的所有縮排無序列表元素 (ul),儘管嘗試將邊距、填充和文字縮排設為 0。雖然將文字縮排設定為負值似乎可以竅門,這是唯一的方法嗎? 答案在於將列表樣式和左填充設為空。透過執行以下程式碼,即可達到想要的效果:ul { ...
    程式設計 發佈於2024-11-15
  • 使用 Pandas“apply”函數將函數應用於多列時如何修復錯誤?
    使用 Pandas“apply”函數將函數應用於多列時如何修復錯誤?
    多列的Pandas“apply”函數故障排除嘗試使用“apply”將函數應用於Pandas 資料框中的多列時' 函數時,如果列名未包含在字串中或函數定義中出現語法錯誤,使用者可能會遇到錯誤訊息。 要解決未定義名稱的問題,請確保指定列名在單引號或雙引號內。例如,不要使用 'row[a]...
    程式設計 發佈於2024-11-15
  • 為什麼應該避免在函數簽名中使用“throw”?
    為什麼應該避免在函數簽名中使用“throw”?
    函數簽名中“Throw”的危險雖然在函數簽名中加入“throw”關鍵字可能很誘人明確聲明潛在的例外情況,強烈建議不要這樣做。儘管其目的看似簡單,但有幾個技術原因導致這種方法被認為是一個糟糕的選擇。 編譯器限制編譯器無法強制執行會產生一個重大問題函式簽章中宣告的例外規格。因此,編譯器無法驗證函數是否確...
    程式設計 發佈於2024-11-15
  • 如何在 MySQL 中將行轉置為列:超越 GROUP_CONCAT 的限制?
    如何在 MySQL 中將行轉置為列:超越 GROUP_CONCAT 的限制?
    在MySQL 中將行轉置為列:探索替代技術在MySQL 中將行轉置為列:探索替代技術問題: 我們如何在MySQL 查詢中有效地將行轉置為列? 答案: MySQL 本質上並沒有提供直接的機制來轉置整個結果 套。但是,我們可以探索替代方法來實現所需的轉換。 儘管 GROUP_CONCAT 在將行轉換為單...
    程式設計 發佈於2024-11-15
  • 為什麼我的 Font Awesome 圖示沒有渲染?
    為什麼我的 Font Awesome 圖示沒有渲染?
    Font Awesome 圖示不渲染:原因與解決方案Font Awesome 圖示是增強網頁視覺吸引力的熱門選擇。然而,儘管包含了所需的 CSS 和 HTML,但有些使用者還是遇到了圖示無法正確呈現的問題。本文探討了此問題的潛在原因並提供了解決方案。 一個常見問題是 CDN 連結不正確。確保Font...
    程式設計 發佈於2024-11-15
  • std 命名空間內的專業化有哪些限制和允許?
    std 命名空間內的專業化有哪些限制和允許?
    std 命名空間中的專業化:限制和允許儘管能夠為std 命名空間添加明確專業化,但某些模板有明確的禁止。了解這些限制對於確保使用 std 命名空間特化的程式碼的有效性至關重要。 特化禁止的模板numeric_limits: 不允許非算術標準類型(例如, complex).shared_ptr: 必須...
    程式設計 發佈於2024-11-15
  • CSS 圖靈完備嗎?
    CSS 圖靈完備嗎?
    CSS 是圖靈完備的。這意味著,如果您將 CSS 視為適當的 HTML 檔案和一種使用者互動類型,則可以執行任意不可計算的功能。此外,Webkit CSS 可以對規則 110 進行編碼以證明圖靈完備性。這意味著 CSS 是一種快速、獨立於平台、圖靈完整的語言。
    程式設計 發佈於2024-11-15

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3