在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
一、元素偏移量 offset 系列offset 翻译过来就是偏移量, 我们使用 offset 系列相关属性可以动态的得到该元素的位置(偏移)、大小等。
offset常用的属性有: 例如:给定一个子盒子和一个父盒子,并给他们一定的大小,来看看这些属性是怎样获得的: <style> *{ margin: 0px; padding: 0px; } .father{ position: relative; margin-left: 50px; margin-top: 10px; width: 200px; height: 200px; background-color: brown; } .son{ width: 100px; height: 100px; background-color: cornflowerblue; } </style> </head> <body> <div class="father"> <div class="son"></div> </div> <script> var father = document.querySelector('.father'); var son = document.querySelector('.son') console.log('father.offsetLeft',father.offsetLeft); console.log('father.offsetTop',father.offsetTop); console.log('son.offsetWidth',son.offsetWidth); console.log('son.offsetHeight',son.offsetHeight); </script> </body> 打印结果为: 我们知道,offset可以帮助我们得到元素的大小和父元素,但是style属性也可以获取到相关属性,那么,他们的区别又是什么呢?
二、元素可视区 client 系列client 翻译过来就是客户端,我们使用 client 系列的相关属性来获取元素可视区的相关信息。通过 client 系列的相关属性可以动态的得到该元素的边框大小、元素大小等。 例如,给定一个带边框的盒子,返回这些属性,看看结果。 <style> .box{ width: 200px; height: 200px; background-color: darkorchid; border: 20px solid #ccc; } </style> </head> <body> <div class="box"></div> </body> <script> var box = document.querySelector('.box') console.log('box.clientWidth:'+box.clientWidth); console.log('box.clientWidth:'+box.clientWidth); console.log('box.clientWidth:'+box.clientWidth); console.log('box.clientTop:'+box.clientTop); </script> 结果为: 可以发现,通过client系列的得到的盒子大小并不包含盒子的边框。 三、元素滚动 scroll 系列scroll 翻译过来就是滚动的,我们使用 scroll 系列的相关属性可以动态的得到该元素的大小、滚动距离等。 例如:还是上面案例的盒子,我们打印其scroll系列属性,看看结果 <style> .box{ width: 200px; height: 200px; background-color: darkorchid; border: 20px solid #ccc; } </style> </head> <body> <div class="box"></div> </body> <script> var box = document.querySelector('.box') console.log('box.scrollWidth:'+box.scrollWidth); console.log('box.scrollHeight:'+box.scrollHeight); console.log('box.scrollLeft:'+box.scrollLeft); console.log('box.scrollTop:'+box.scrollTop); </script> 结果为: 我们发现得到的盒子高度和宽度都是我们的给定值,和client系列得到的值是一样的,那么他们的区别是什么呢?现在我们给盒子里面添加超过盒子高度的内容: <div class="box"> 王欢在学前端<br><br> 王欢在学前端<br><br> 王欢在学前端<br><br> 王欢在学前端<br><br> 王欢在学前端<br><br> 王欢在学前端<br><br> 王欢在学前端 </div> 打印结果为: 可以发现此时打印的盒子高度变大了,其实这个值是指盒子加上文字后自身实际的高度。 大家还会发现两次打印的box.scrollLeft和box.scrollTop的值都是0,这又是什么意思呢? 现在我们通过overflow:auto将盒子内超出的内容让其以滚动条的形式显示,然后给他添加滚动事件,如下所示: var box = document.querySelector('.box') box.addEventListener('scroll',function(){ console.log('box.scrollTop:'+box.scrollTop); }) 效果为; 发现得到的值是随着滚动来变化的,其实,box.scrollTop返回的是被卷去的上侧距离,如下图所示: 以上就是JavaScript实现三种常用网页特效(offset、client、scroll系列)的详细内容,更多关于JavaScript网页特效的资料请关注极客世界其它相关文章! |
请发表评论