offset系列,client系列,scroll系列回顾

一 scroll系列属性      ——滚动
1 scrollHeight/scrollWidth 标签内部实际内容的高度/宽度
ele.scrollHeight 有两种情况,
当内容超出盒子范围后,返回的是内容的高度,包括padding,从顶部内侧到内容的最外部分。
当内容不超出盒子范围时,返回的是盒子的高度,就是 ele.scrollHeight == ele.clientHeight,最小值就是ele.clientHeight
ele.scrollWidth 情况同 ele.scrollHeight一样。
当内容超出盒子范围后,返回的是内容的宽度,包括padding,从左边内侧到内容的最外部分。
当内容不超出盒子范围时,返回的是盒子的宽度,就是 ele.scrollWidth == ele.clientWidth,最小值就是ele.clientHeight
各个浏览器说法不一:
IE、Opera 认为 scrollHeight 是网页内容实际高度,可以小于 clientHeight。
NS、FF 认为 scrollHeight 是网页内容高度,不过最小值是 clientHeight。
2 scrollTop/scrollLeft
ele.scrollTop  滚动时返回的是被卷去部分的顶部到可视区域的顶部,看图
ele.scrollLeft  滚动时返回的是被卷去部分的左侧到可视区域的左侧,看图
函数封装    ----获取卷曲的宽度和高度
function myScroll() {return {top: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0,left: window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0  }
}
eg:document.documentElement-----html标签
       document.body            ------body内部
ps! 想要实时获取页面卷曲的高度或宽度,必须在事件内进行
window.onscroll = function(){}
3 scrollTo
window.scrollTo(1500,2000);//参数1 表示横向滚动到的位置 //参数2 表示纵向滚动到的位置
二 client系列属性        ——可视

1.  clientWidth/clientHeight  
ele.clientWidth 返回元素内部空间的宽度(width+padding),是一个只读属性。不包含border和margin以及纵向滚动条。
(ele.clientWidth = width + padding - 滚动条的高度)
ele.clientHeight 返回元素内部空间的高度(height+padding),是一个只读属性。不包含border和margin以及横向滚动条。
(Ele.clientHeight = height + padding - 滚动条的宽度)
@ 和offsetWidth/offsetHeight 的区别:
offsetWidth包含border,而clientWidth不包含border。
scrollHeight的最小值和clientHeight相同
  2  clientTop/clientLeft
ele.clientTop 表示一个元素的左边框的宽度,以像素表示。是一个只读属性
如果元素的文本方向是从右向左(RTL, right-to-left),并且由于内容溢出导致左边出现了一个垂直滚动条,则该属性包括滚动条的宽度(默认17px)。
clientLeft 不包括左外边距和左内边距
(ele.clientLeft = border-left-width + 滚动条的宽度)
ele.clientLeft 一个元素顶部边框的宽度(以像素表示)。不包括顶部外边距或内边距。
(ele.clientTop = border-top-width) 
函数封装:
function myClient() {return {width: window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth || 0,height: window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight || 0}
}

 

三  offset系列的属性
 1.  offsetWidth/offsetHeight  
ele.offsetWidth    它返回该元素的像素宽度,(box-sizing:content-box)默认情况下:宽度包含该元素的水平内边距和边框,(除了margin以外:border+padding+width)且是一个整数         ele.offsetHeight   它返回该元素的像素高度 (box-sizing:content-box)默认情况下:高度包含该元素的垂直内边距和边框,(除了margin以外:border+padding+width)且是一个整数       
ps:元素的offsetHeight,offsetWidth是一种元素CSS高度的衡量标准,包括元素的边框、内边距和元素的水平滚动条或纵向滚动条(如果存在且渲染的话),不包含:before或:after等伪类元素的高度
offsetWidth和offsetHeight是用来得到元素的大小
@offsetHeight 和 style.height的区别
demo.style.height只能获取行内样式,如果样式写到了其他地方,甚至根本就没写,便无法获取
style.height是字符串(而且带单位),offsetHeight是数值
demo.style.height可以设置行内样式,offsetHeight是只读属性
2.  offsetLeft/offsetTop    
ele.offsetLeft     到距离自身最近的(带有定位的)父元素的 左侧 的距离,如果所有父级都没有定位则以body 为准.
offsetLeft 是自身border左侧到父级padding左侧的距离  -----数值
ele.offsetTop      到距离自身最近的(带有定位的)父元素的 顶侧 的距离,如果所有父级都没有定位则以body 为准.      ----数值
offsetLeft和offsetTop是用来得到元素的位置
@offsetLeft和style.left的区别
style.left只能获取行内样式
offsetLeft只读,style.left可读可写
offsetLeft是数值,style.left是字符串并且有单位px
如果没有加定位,style.left获取的数值可能是无效的
最大区别在于offsetLeft以border左上角为基准,style.left以margin左上角为基准
计算方式:从定位的父盒子的边框内部,计算到子盒子的边框外部(边框到边框)
特点:
1、offsetLeft属性没有单位,是纯数值
2、offsetLeft属性是只读的,不可修改
3、offsetLeft属性若有小数,会四舍五入进位
 3.offsetParent   获取到当前元素外面的定位父盒子
HTMLElement.offsetParent 是一个只读属性,返回一个指向最近的(closest,指包含层级上的最近)包含该元素的定位元素。如果没有定位的元素,则 offsetParent 为最近的 table, table cell 或根元素(标准模式下为 html;quirks 模式下为 body)。当元素的 style.display 设置为 "none" 时,offsetParent 返回 null。
(offsetParent 很有用,因为 offsetTop 和 offsetLeft 都是相对于其内边距边界的。)
@ offsetParent和parentNode的区别
父元素parentNode,一定是亲爹,外面紧挨着的元素
定位父盒子offsetParent,干爹(有可能是亲爹,也可能不是亲爹)
 方法:
// 获取所选元素到浏览器最左边的距离
var getOffsetLeft = function(obj){var tmp = obj.offsetLeft;var val = obj.offsetParent;while(val != null){tmp += val.offsetLeft;val = val.offsetParent;}return tmp;
}

  

//获取所选元素到浏览器最上边的距离
var getOffsetTop = function(obj){var tmp = obj.offsetTop;var val = obj.offsetParent;while(val != null){tmp += val.offsetTop;val = val.offsetParent;}return tmp;
}

转载于:https://www.cnblogs.com/sqh17/p/10217159.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/249886.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

项目开发中的自我总结

最近忙的要死,因为新开发了两个项目.现在已经测试完毕了,准备部署到线上了. 然后不能白忙活吧,忙活完也得写点总结和经验吧,以后也有个记录. 1.一个bootstrapjquerylayuilaravel 5.4开发的一个后台系统 比较朴素 2.一个前后端分离的vuelaravel 5.4 开发的商家系统 我只负责后端…

数组黑科技(偏性能方面)未完待更新...

数组去重最优解:Array.prototype.unique function () {var tmp new Map();return this.filter(item > {return !tmp.has(item) && tmp.set(item,1);})}搭配使用 Array.from(foo); // ["f", "o", "o"]let s new Set([f…

控制台添加log4net

1.添加nuget包 log4net 2.app.config配置 <?xml version"1.0" encoding"utf-8"?> <configuration> <configSections><section name"log4net" type"log4net.Config.Log4NetConfigurationSectionHandler, log4net&quo…

touchWX 自定义组件以及传值

创建如图文件 index.wxc: <template><view class"wx-test" bindtap"handleTap">{{ msg }}{{dataIndex}}</view> </template> <script>export default {properties: {dataIndex: {type: String,value: default value,}},data…

vue 初始框架

VueJs讲解初始框架 一、启动项目 第一步&#xff1a;cmd进入项目文件里&#xff0c;运行npm run dev 启动项目 这里说明启动端口号是8080 第二步&#xff1a;往页面输入&#xff1a;localhost:8080 二、解析渲染步骤 先看整体框架样式和index.html&#xff1a; 从上面我…

Country Road Aizu - 2104

题目链接&#xff1a; https://vjudge.net/problem/Aizu-2104 题解&#xff1a; 咋说啊&#xff0c;一言难尽&#xff0c;花了半小时写出来的&#xff0c;卡了十分钟才恍然大明白是排序。 具体就是让每个村子都通上电&#xff0c;变压器在的村子&#xff0c;与变压器连线点线长…

IdentityServer4【QuickStart】之使用asp.net core Identity

使用asp.net core Identity IdentityServer灵活的设计中有一部分是可以将你的用户和他们的数据保存到数据库中的。如果你以一个新的用户数据库开始&#xff0c;那么&#xff0c;asp.net core Identity是一个选择。这个示例演示了如何在IdentityServer中使用asp.net core Ientit…

vue demo1

1.开发工具 试过sublime&#xff0c;现在转战vscode&#xff0c;觉得很顺手&#xff0c;总之啥工具习惯就好。 vscode用着不错的插件&#xff0c;推荐安装。 2.项目目录介绍 vue-cli生成的项目目录有点多&#xff0c;初看有点懵&#xff0c;梳理一下会好很多。 ├── ind…

CentOS下防御或减轻DDoS攻击方法(转)

查看攻击IP 首先使用以下代码&#xff0c;找出攻击者IP netstat -ntu | awk {print $5} | cut -d: -f1 | sort | uniq -c | sort -n 将会得出类似如下的结果&#xff1a; 1 114.226.9.132 1 174.129.237.157 1 58.60.118.142 1 Address 1 servers) 2 118.26.131.78 3 123.125.1…

vscode - 添加背景图片

首先&#xff0c;CtrlShiftP安装backround &#xff0c; 而后重启vscode会有默认的背景图片 修改背景图&#xff0c;可自定义三张 具体请看gif图 最开始时&#xff0c;发现png根本不是全透明&#xff0c;用ps处理了一下&#xff08;下列所有操作均字母组合&#xff09; 1.1 Ctr…

关于Vue.use()详解

问题 相信很多人在用Vue使用别人的组件时&#xff0c;会用到 Vue.use() 。例如&#xff1a;Vue.use(VueRouter)、Vue.use(MintUI)。但是用 axios时&#xff0c;就不需要用 Vue.use(axios)&#xff0c;就能直接使用。那这是为什么呐&#xff1f; 答案 因为 axios 没有 install。…

分布式工具的一次小升级⏫

前言 之前在做 秒杀架构实践 时有提到对 distributed-redis-tool 的一次小升级&#xff0c;但是没有细说。 其实主要原因是&#xff1a; 秒杀时我做压测&#xff1a;由于集成了这个限流组件&#xff0c;并发又比较大&#xff0c;所以导致连接、断开 Redis 非常频繁。 最终导致获…

浅谈vue $mount()

Vue 的$mount()为手动挂载&#xff0c;在项目中可用于延时挂载&#xff08;例如在挂载之前要进行一些其他操作、判断等&#xff09;&#xff0c;之后要手动挂载上。new Vue时&#xff0c;el和$mount并没有本质上的不同。 具体见代码&#xff1a; 顺便附上vue渲染机制流程图&a…

论一个程序员的自我修养-从一张图片说起

故事起源 本来今天想写.NET Core实战之CMS系统第十五篇文章的。哈&#xff0c;奈何今天在新生命人脉群里面看到石头哥分享的一张图片&#xff0c;然后大家就议论了起来&#xff0c;不过我看的很懵逼&#xff0c;这图什么意思啊&#xff1f;当一个朋友讲述了这个图片背后的故事的…

c/c++ 继承与多态 文本查询的小例子(非智能指针版本)

问题&#xff1a;在上一篇继承与多态 文本查询的小例子&#xff08;智能指针版本&#xff09;在Query类里使用的是智能指针&#xff0c;只把智能指针换成普通的指针&#xff0c;并不添加拷贝构造方法&#xff0c;会发生什么呢&#xff1f; 执行时&#xff0c;代码崩掉。 分析下…

HTML渲染过程详解

由于本人对http协议以及dns对url的解析问题并不了解&#xff0c;所以这里之探讨url请求加载到浏览器端时&#xff0c;浏览器对html的解析到呈现过程&#xff0c;后来经过几位道友分享&#xff0c;整理了一下url解析的过程&#xff0c;如下&#xff1a; 用户输入url地址&#x…

vue之router-view组件的使用

开发的时候有时候会遇到一种情况&#xff0c;比如 &#xff1a;点击这个链接跳转到其他组件的情况&#xff0c;通常会跳转到新的页面&#xff0c;蛋是&#xff0c;我们不想跳转到新页面&#xff0c;只在当前页面切换着显示&#xff0c;那么就要涉及到路由的嵌套了&#xff0c;也…

go 区分指针

先看一段代码 先放一段代码&#xff0c;人工运行一下&#xff0c;看看自己能做对几题&#xff1f; package mainimport "fmt"func main() {var a int 1 var b *int &a var c **int &b var x int *b fmt.Println("a ",a) fmt.Println("&a…

ajax和axios、fetch的区别

1.jQuery ajax $.ajax({type: POST,url: url,data: data,dataType: dataType,success: function () {},error: function () {} });传统 Ajax 指的是 XMLHttpRequest&#xff08;XHR&#xff09;&#xff0c; 最早出现的发送后端请求技术&#xff0c;隶属于原始js中&#xff0c…

函数函数sigaction、signal

函数函数sigaction 1. 函数sigaction原型&#xff1a; int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact); 分析&#xff1a; 参数 signum &#xff1a;要捕获的信号。参数act&#xff1a;truct sigaction 结构体&#xff0c;后面具体讲解传入…