css - 关于offsetLeft和offsetTop
问题描述
offsetLeft不是当前元素的左外边框到包含元素的左内边框之间的像素距离吗?为什么多出了8px
<!DOCTYPE html><html> <head><meta charset='utf-8'><title>test2</title><style media='screen'> .cc{padding: 50px 30px; } .fc{background-color: blue;width:300px;height: 200px; }</style> </head> <body><p class='cc'> <p > </p></p> </body> <script type='text/javascript'>var fc = document.querySelector(’.fc’);console.log(fc.offsetLeft+’:’+fc.offsetTop); </script></html>

问题解答
回答1:offsetLeft 和 offsetTop 返回的是相对于 offsetParent 元素的距离,而 offsetParent 指的是一个元素最近的父级定位元素,如果没有定位元素就是文档根节点。
你现在输出的值加上 body 本身有 8px 的 margin,其实是没错的。你可以加个 body { margin:0 } 或者给父级元素加上定位,输出就是你期望的数了。
回答2:默认有8px的margin。使用*{margin:0;}清除默认样式。
相关文章:
1. 请教,关于python字典,合并相同值的键的实现方法2. node.js - 问个问题 Uncaught (in promise)3. angular.js - 如何控制ngrepeat输出的个数4. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????5. 网页爬虫 - python requests爬虫,如何post payload6. javascript - 最近用echarts做统计图时遇到两个问题!!7. python3.x - python3.5.2安装时make报错求助8. mysql_replication - mysql读写分离时如果单台写库也无法满足性能怎么解决9. javascript - 求一款靠谱点的移动端图片查看器插件,老司机速进!10. javascript - 在使用 vue.js element ui的时候 怎么样保留table翻页后check的值?

网公网安备