window 和 document :

window 对象表示浏览器打开的窗口,可以省略

document对象(浏览器的html文档)是window对象的一部分

document.body等于window.document.body

document.location === window.loacation

document.location.href === location.href(location是一个对象)

window相关的 width和height:

window.innerHeight是真的可视区域高度(除去了各种任务栏工具栏宽高,随窗口缩放或f12改变)

screen 的 width、height、availWidth、availHeight 是固定不变的

window.innerHeight 和 window.innerWidth 不兼容ie8及以下版本

兼容问题推荐使用 获取浏览器窗口可视区域大小

var w= document.body.clientWidth || document.documentElement.clientWidth;

var h= document.body.clientHeight || document.documentElement.clientHeight;

document(element)相关的 width和height:

1、document.body.clientHeight是元素真实高度 (无论有无任务栏工具栏遮掩及窗口缩放)tip:滚动条宽度约17px

clientHeight = content + 2.padding;

clientLeft和clientTop返回元素周围边框的厚度,如果不指定边框或者不定位元素,其值为0

即:

clientLeft = border-left-width;

clientTop = border-top-width;

2、document.body.offsetWidth是元素加入滚动条的整体宽度

offsetWidth = content + 2.padding + 2.(border-width)+滚动条;

所以滚动条宽度= offsetWidth - clientWidth

3、document.body.scrollHeight是元素实际的子元素内容高度

无滚动轴时:scrollHeight == clientHeight = style.height+2.padding;

有滚动轴时:scrollHeight == 实际子元素的高度+2.padding;

element.offsetLeft和element.style.left相对于父对象的左边距

document.getElementById("v1").offsetLeft 只读、数值、包括margin

document.querySelector("#v1").style.left 可读可写、字符串px

event对象坐标:

clientX和clientY ----> 相对于浏览器(可视区左上角0,0)的坐标

screenX和screenY ----> 相对于设备屏幕左上角的(0,0)的坐标

offsetX和offsetY ----> 相对于事件源左上角(0,0)的坐标

pageX和pageY ----> 相对于整个网页左上角(0,0)的坐标

js宽高实际应用

1、可视区域加载图片或元素
function showDiv(){
var myPic=document.getElementById("showDiv");
var clientH=window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight;
var picTop=myPic.offsetTop;
if(picTop<=clientsH+scrollTop){
myPic.classList.add("fadeInLeft");
//图片延迟加载:把图片路径先放在一个属性中,再给src
}
}
window.onscroll=showDiv;

classList H5新API

classList 属性返回元素的类名,作为 DOMTokenList 对象。

该属性用于在元素中添加,移除及切换 CSS 类。

classList 属性是只读的,但你可以使用 add() 和 remove() 方法修改它。

http://www.runoob.com/jsref/prop-element-classlist.html

2、网页滚动底部或顶部
function scrollTopBottom(){
var myPic=document.getElementById("showDiv");
var clientH=window.innerHeight||document.documentElement.clientHeight||document.body.clientHeight;
var scrollTop=document.body.scrollTop;
var wholeHeight=document.body.scrollHeight;
if(scrollTop+clientH>=wholeHeight){
alert("滚到底部了");
}
if(scrollTop==0){
alert("滚动到顶部了")
}
}
window.onscroll=scrollTopBottom;

jquery的宽和高

$(ele).innerHeight() == ele.clientHeight

$(ele).outerHeight() == ele.offsetHeight

  • .height() //元素本身高度
  • .innerHeight() //在height的基础上加了padding值
  • .outerHeight() //在innerHeight的基础上加了border
  • .outerHeight(true) //在innerHeight的基础上加了border和margin

$(ele).position().left == ele.offsetLeft

整个元素算上margin、padding后的样子

  • .offset() //获取匹配元素在当前视口的相对偏移
  • .position() //获取匹配元素相对父元素的偏移

jquery宽高实际应用

1、可视区域加载图片或元素
$(window).scroll(function(){
var clientH=$(window).height();
var scrolltop=$(window).scrollTop();
var picTop=$("#showDiv").offset().top;
if(clinetH+scrollTop>=picTop){
$("#showDiv").addClass("fadeInLeft");
}
})

js 和 jquery的宽高的更多相关文章

  1. js获取隐藏元素宽高的方法

    网上有一些js获取隐藏元素宽高的方法,但是可能会存在某些情况获取不了. 例如: <!DOCTYPE html> <html lang="en"> <h ...

  2. JS获取图片实际宽高及根据图片大小进行自适应

    JS获取图片实际宽高,以及根据图片大小进行自适应  <img src="http://xxx.jpg" id="imgs" onload="ad ...

  3. JS获取图片实际宽高

    JS获取图片实际宽高,以及根据图片大小进行自适应 <img src="http://xxx.jpg" id="imgs" onload="ada ...

  4. 前端 JS 获取 Image 图像 宽高 尺寸

    前端 JS 获取 Image 图像 宽高 尺寸 简介 项目中用到获取图片的原始尺寸,然后适配宽高:网上的大部分前端解决方案,都是new Image()后,在onload事件中获取image的尺寸. 在 ...

  5. js自定义获取浏览器宽高

    /** * @description js自定义获取浏览器宽高 * * IE8 和 IE8 以下的浏览器不兼容 * window.innerWidth * window.innerHeight * * ...

  6. 原生js获取宽高与jquery获取宽高的方法的关系

    说明:1.因为获取高度的情况跟获取宽度的情况一样,所以以下只说获取宽度的情况.  2.以下所说的所有方法与属性所返回的值都是不带单位的.  3.为了方便说明,以下情况采用缩写表示:  obj -> ...

  7. JS获取元素的宽高以及offsetTop,offsetLeft等的属性值

    基本介绍 $(obj).width()与$(obj).height() $(obj).width()与$(obj).height() :jquery方式获取元素的宽高,不包括滚动条与工具条 $(obj ...

  8. 写个js动态调整图片宽高 (原创)

    <body style="TEXT-ALIGN: center;"> <div id="testID" style="backgro ...

  9. JS基础篇--JS获取元素的宽高以及offsetTop,offsetLeft等的属性值

    $(obj).width()与$(obj).height() $(obj).width()与$(obj).height() :jquery方式获取元素的宽高,不包括滚动条与工具条 $(obj).wid ...

随机推荐

  1. 海量数据GPS定位数据库表设计

    在开发工业系统的数据采集功能相关的系统时,由于数据都是定时上传的,如每20秒上传一次的时间序列数据,这些数据在经过处理和计算后,变成了与时间轴有关的历史数据(与股票数据相似,如下图的车辆行驶过程中的油 ...

  2. Java中的异常处理从概念到实例

    1.概念 采用新的异常处理机制 在以往的程序开发过程中,经常采用返回值进行处理.例如,在编写一个方法,可以返回一个状态代码,调用者根据状态代码判定出错与否.若状态代码表示一个错误,则调用这进行相应的处 ...

  3. java基础面试题:写clone()方法时,通常都有一行代码,是什么?

    clone()方法 与new constructor()构造器创建对象不同 是克隆一个新的对象 package com.swift; public class Clone_Test { public ...

  4. v4l2解析

    v4l2的学习建议和流程解析: http://www.cnblogs.com/silence-hust/p/4464291.html 补充: 枚举设备所支持的image format: VIDIOC_ ...

  5. linux普通文件权限和系统目录权限的实践及结论

    测试结论:linux普通文件的读.写.执行权限说明 1.可读r:表示具有读取\阅读文件内容的权限 2.可写w:表示具有新增.修改文件内容的权限 1)如果没有r配合,那么vi编辑文件会提示无法编辑(但可 ...

  6. php - 去除php代码中的多余空格

    <?php class Test{ public function test(){ $tmplContent = file_get_contents('./test.php'); $tmplCo ...

  7. 利用DOM的方式点击切换图片及修改文字

    本案例主要学习理解,用到的几个DOM方法 01.getAttribute()方法,获取元素的属性值 02.setAttribute('src',source) 方法,用后边的值修改前边这个元素的属性值 ...

  8. python3 包的发布

    发布流程大概如下 1. 首先需要有一个python包,就是一个文件夹,但是此文件夹下面有__init__.py文件,里面内容是 现在要发布包TestMsg,这就是一个python包.在同级目录下新建s ...

  9. A1075 PAT Judge (25)(25 分)

    A1075 PAT Judge (25)(25 分) The ranklist of PAT is generated from the status list, which shows the sc ...

  10. 牛客第四次多校Maximum Mode

    链接:https://www.nowcoder.com/acm/contest/142/G来源:牛客网 题目描述 The mode of an integer sequence is the valu ...