jquery獲取元素各種寬高及頁面寬高總結

来源:https://www.cnblogs.com/guoliangstar/archive/2019/08/08/11321480.html
-Advertisement-
Play Games

window.onload=function(){ var a = $("#div").width(),//width()返回元素的寬高,不包括padding/border/margin b = $("#div").innerWidth(),//innerWidth()返回元素的寬高 + paddi ...


window.onload=function(){
  var a = $("#div").width(),//width()返回元素的寬高,不包括padding/border/margin
  b = $("#div").innerWidth(),//innerWidth()返回元素的寬高 + padding
  c = $("#div").outerWidth(),//outerWidth()返回元素的寬高 + padding + border
  d = $("#div").outerWidth(true);//outerWidth(true)返回元素寬高 + padding + border + margin
  console.log(a,b,c,d);
}

瀏覽器當前視窗文檔body的高度:
  $(document.body).height();
瀏覽器當前視窗文檔body的寬度:
  $(document.body).width();
獲取滾動條到頂部的垂直高度 (即網頁被捲上去的高度)
  $(document).scrollTop();
獲取滾動條到左邊的垂直寬度 :
  $(document).scrollLeft();
獲取或設置元素的寬度:
  $(obj).width();
獲取或設置元素的高度:
  $(obj).height();
某個元素的上邊界到body最頂部的距離:obj.offset().top;(在元素的包含元素不含滾動條的情況下)
某個元素的左邊界到body最左邊的距離:obj.offset().left;(在元素的包含元素不含滾動條的情況下)
返回當前元素的上邊界到它的包含元素的上邊界的偏移量:obj.offset().top(在元素的包含元素含滾動條的情況下)
返回當前元素的左邊界到它的包含元素的左邊界的偏移量:obj.offset().left(在元素的包含元素含滾動條的情況下)

開發時遇到的問題:

  內容高度不夠,底部上移問題

解決方案:

  判斷內容高度差多少,施加在底部的margin-top上:

  var gap = document.documentElement.clientHeight - $("footer").height() - $("header").height();

  if( gap > $(".container").height()){

    $("footer").css({
      "margin-top":gap - $(".container").height()+"px"
    })
  }


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

-Advertisement-
Play Games
更多相關文章
  • <form>元素: <input>元素: 常用屬性: type 文本框類型 name 指定了name的欄位才會被提交(不能用id代替name屬性) placeholder 占位符 value 輸入框中的文本 autofocus 自動聚焦 disabled 禁用 readonly 只讀 require ...
  • 一開始,我使用的是Jquery框架中的$.("#input").readOnly,發現取出的值為undefined,不知道是不是jQuery中不支持獲取標簽屬性的函數, 然後就使用了原生的document.getElementById("input1").readOnly並且可以更改它的值以及取值, ...
  • 寫在前面:前面的內容記錄了JavaScript的一些基本概念,本次主要講解一下JS中常用的語句。 和大多數其他編程語言一樣,JS也主要包括:選擇、迴圈、錯誤檢測、函數等。JS的語句基本是由值、運算符、表達式、關鍵字和註釋構成,但並不是語句一定包含所有以上要素。 電腦程式一般是指能夠被電腦執行的一 ...
  • swiper一款非常好用的輪播插件,支持移動端和PC端,用過很多次了,這次簡單的總結一下。方便以後查找使用,說明一下,下麵的例子是基於swiper 4.0+版本的,如果你是其他的版本,請自行前往官網查看 至於為什麼使用swiper,而不是自己手寫,請看下麵官網的截圖: 開個玩笑,說白了,就是這個確實 ...
  • /** * 對於由簡單類型數據組成的對象為元素組成的數組進行去重操作 * @params {Array} 需要去重的對象數組 * @returns {Array} 去重後的對象數組 */ function distinct(sourceArray) { var resultArray = []; v ...
  • 上一篇講了字元串的解析過程,這一篇來講講標識符(IDENTIFIER)的解析。 先上知識點,標識符的掃描分為快解析和慢解析,一旦出現Ascii編碼大於127的字元或者轉義字元,會進入慢解析,略微影響性能,所以最好不要用中文、特殊字元來做變數名(不過現在代碼壓縮後基本不會有這種情況了)。 每一位Jav ...
  • HTML特殊轉義字元列表 最常用的字元實體Character Entities 顯示說明實體名稱實體編號 半方大的空白 &ensp; &#8194; 全方大的空白 &emsp; &#8195; 不斷行的空白格 &nbsp; &#160; < 小於 &lt; &#60; > 大於 &gt; &#62; ...
  • 什麼是組件? 組件的出現,就是為了拆分Vue實例的代碼量的,能夠讓我們以不同的組件,來劃分不同的功能模塊,將來我們需要什麼樣的功能,就可以去調用對應的組件就可以了。 組件化和模塊化的區別 模塊化:是從代碼邏輯的角度進行劃分的,方便代碼分層開發,保證每個模塊功能的職能單一。例如:NodeJS 組件化: ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...