2022-07-04,jQuery中的offset和style.left的区别

2022-07-04

JS下offsetLeft,style.left,以及jQuery中的offset().left,css(“left”)的区别。

JS下的offsetLeft和style.left,以及jquery的css(“left”),对定位的理解相似,如果父元素中有定位元素,都是相对于上一个定位元素(position不为static)定位。值得一提的是如果没有已经定位的父元素,那么offsetLeft指向的是文档(document)的左边缘,而style.left与css(”left”)指向的是body的左边缘,如果body默认存在margin的话,他们取得的值是不一样的。 此外老生常谈,css(“left”)和style.left是带单位”px”的,而offsetLeft没有单位,另外,style.left必须是内联样式,或者在JS中通过style.left赋值,否则取得的将为空字符串(在内部样式和外部样式中指定left是无效的)。而jquery的css(“left”)没有这一限制,显然使用jquery操作dom的优势就体现出来了。 最后是jquery的offset().left,它永远是相对于文档的左边缘(往往体现为浏览器的左边缘)定位的,这样的话使用jquery就可以在不同的应用场景采用不同的方法来获取元素的位置,相比较原生JS有巨大的优势。

图片[1]-2022-07-04,jQuery中的offset和style.left的区别-唐朝资源网





Document

body{
margin:50px;
/**/

}
.wrap{
width:300px;
height: 300px;
background-color: red;
left:200px;
position:relative;
}
.inner{
position: absolute;
width: 100px;
height: 100px;
left: 50px;
background-color: blue;


}




<div class="wrap" ).style.left);





$(“.wrap”).css(“left”) 200px

图片[2]-2022-07-04,jQuery中的offset和style.left的区别-唐朝资源网

$(“.wrap”).offset().left 250

document.getElementById(“wrap”).offsetLeft 250

document.getElementById(“wrap”).style.left 200px

$(“.inner”).css(“left”) 50px

$(“.inner”).offset().left 300

document.getElementById(“inner”).offsetLeft 50



// 总结 :1.带有offset的就没有单位 px ,js中的 offsetLeft没有单位,jquery中的offset()没有单位,其他有单位

//2.jquery的offset().left,它永远是相对于文档的左边缘,不是body!!!

分类:

技术点:

相关文章:

© 版权声明
THE END
喜欢就支持一下吧
点赞158赞赏 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容