元素的宽高/偏移量
时间:2020-04-19
本文章向大家介绍元素的宽高/偏移量,主要包括元素的宽高/偏移量使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
个人总结
- 通过js来获取元素的宽高以及偏移量
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
html, body{
padding: 0;
margin: 0;
height: 2000px;
}
#div1 {
width: 100px;
height: 100px;
margin: 150px;
padding: 50px;
border: 10px solid black;
}
</style>
</head>
<body>
<div id="div1"></div>
<script type="text/javascript">
const body = document.querySelector('body')
const div = document.getElementById('div1')
//返回的是 content + padding
console.log(div.clientWidth, div.clientHeight) //200 200
//返回的是 border + content + padding
console.log(div.offsetWidth, div.offsetHeight) //220 220
//返回的是距离相对定位父元素的偏移量
console.log(div.offsetLeft, div.offsetTop) //150 150
//返回的是当前body可以滚动区域的宽高
console.log(body.scrollWidth, body.scrollHeight)
//关于body的scrollTop/Left 各个浏览器有不同的版本
//ie: document.body.scrollTop 或 document.documentElement.scrollTop;
//chrome,firefox: document.documentElement.scrollTop
//safari: window.pageYOffset ;
body.onscroll = function () {
console.log(document.documentElement.scrollTop, document.documentElement.scrollLeft)
}
//可以封装一个函数解决各个浏览器body的scrollTop/Left问题
function getScroll(){
return {
left: window.pageXOffset || document.documentElement.scrollLeft || document.body.scrollLeft || 0,
top: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0
}
}
</script>
</body>
</html>
原文地址:https://www.cnblogs.com/sheep2/p/12731937.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- SQL 行转列+窗口函数的实例
- 回答一下这 10 个最常见的 Javascript 问题
- 千万级数据表选错索引导致的线上慢查询事故
- 递归优化
- Webshell 高级样本收集
- 处理Sprint Boot与Storm1.2.2日志实现的冲突,使用logback记录日志
- Docker 命令总结
- python主题LDA建模和t-SNE可视化
- cannot import name ‘imresize‘ from ‘scipy.misc‘
- 一分钟基础:计算机为什么使用二进制?
- 使用hibernate validate做参数校验
- Leetcode No.4 寻找两个正序数组的中位数
- R语言 RevoScaleR的大规模数据集决策树模型应用案例
- 快速学习-sentinel控制台
- 快速学习-sentinel注解支持