寻找(获取)当前页面中最大的 z-index 值的方法(js组件层级计数器)

思路:  我们可以把 DOM 中的所有元素集合起来,然后转化成一个数组,然后我们遍历这个数组,把所有元素的 z-index 值提取出来,然后就形成了一个纯数字的数组,最后从中取到最大值,就是当前页面中的最大的 z-index 值了。

将我们的思路,转化为代码

1.找到所有元素,转化成数组 (下面方法都可以)
Array.from(document.querySelectorAll('body *'));
Array.from(document.body.querySelectorAll('*'));
[...document.body.querySelectorAll('*')];
[...document.all]

2.使用window.getComputedStyle()方法获取元素的z-index属性

window.getComputedStyle(document.body).zIndex || 0;

这样,我们就可以拿到元素的 z-index 值了。但是问题是,我们拿到的不一定是一个数字,而可能是 auto 这样的字符串值,我们就需要处理一下了。
正常写法 Number(window.getComputedStyle(document.body).zIndex)
简写写法 +window.getComputedStyle(document.body).zIndex


3.数组中寻找最大值(下面方法都可以)
Math.max.apply(null, arr);
Math.max(...arr);
arr.reduce(a,b) => {return a > b ? a : b}
当然,还可以用其他方法

4.最后,组装方法

【document.all已废弃 HTML5
该特性已经从 Web 标准中删除,虽然一些浏览器目前仍然支持它,但也许会在未来的某个时间停止支持,请尽量不要使用该特性。】

function getZindex(){
    var arr = [...document.all].map(e => +window.getComputedStyle(e).zIndex || 0) ;
    return arr.length ? Math.max(...arr) : 1
}

function getZindexTwo(){
    return [...document.all].reduce( (r, e) => Math.max(r, +window.getComputedStyle(e).zIndex || 0), 0) || 1
}
 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值