首页
学习
活动
专区
工具
TVP
发布

js判断是否是子元素

文本俺将跟大家介绍,如何判断一个当前点击的元素是否是指定元素的子元素。 解决思路: 俺给父元素指定了一个id,并使用这个循环检查当前元素是否属于它的子元素。...BODY'){ if (obj == parentObj){ return true; } obj = obj.parentNode; } return false; } 方法二:jquery代码 //判断...:当前元素是否是被筛选元素的子元素 jQuery.fn.isChildOf = function(b){ return (this.parents(b).length > 0); }; //判断:当前元素是否是被筛选元素的子元素或者本身...方法三: const isDescendant = (el, parentId) => { let isChild = false if (el.id === parentId) { //判断是否是其本身...} else { //处理不是子元素的情况 } }) while循环中,俺使用赋值运算符=进行迭代,直到不再有父节点,本例中为el.parentNode返回null时, while

10.6K00
您找到你想要的搜索结果了吗?
是的
没有找到

判断元素是否视窗之内

本文作者:IMWeb elvin 原文出处:IMWeb社区 未经同意,禁止转载 作为一名前端工程师我们经常需要判断目标元素是否视窗之内或者和视窗的距离小于一个值(例如 100 px),从而实现一些常用的功能...目前流行的方式是通过 Element.getBoundingClientRect() 拿到元素的相关位置信息后进行手动的判断,但是这种方法由于运行在 JavaScript的主进程,所以当需要监听的元素较多时...那么仔细想一想,其实在浏览器渲染的时候,它就知道了元素是否视窗之内,自身面积有多少视窗之内。...下图是使用 Element.getBoundingClientRect() 进行计算实现的效果,可以看到有非常明显的卡顿,主要是因为需要对每一个元素都进行计算,判断它们是否视窗之内。...如果一个元素视窗之内的话,那么它一定满足下面四个条件: top 大于等于 0 left 大于登录 0 bottom 小于等于视窗高度 right 小于等于视窗宽度 考虑到不同浏览器的兼容性,可以写出来如下的函数用于判断元素是否视窗之内

2K20

js判断元素某个区域内是否可见(转)

getBoundingClientRect介绍 getBoundingClientRect获取元素位置 getBoundingClientRect用于获得页面中某个元素的左,,右和下分别相对浏览器视窗的位置...right是指元素右边界距窗口最左边的距离,bottom是指元素下边界距窗口最上面的距离。 getBoundingClientRect()最先是IE的私有属性,现在已经是一个W3C标准。...document.documentElement.scrollLeft; var Y =this.getBoundingClientRect().top+document.documentElement.scrollTop; getBoundingClientRect判断元素是否可视区域...以前的办法是通过各种offset判断元素是否可见,网上很多教程,大家可以自己去查找。 ...getBoundingClientRect是获取可视区域相关位置信息的,使用这个属性来判断更加方便: function isElementInViewport (el) { var rect =

7.5K20

Go 判断元素是否切片中

文章目录 1.问题 2.遍历查询 3.map 查询 4.性能对比 5.转换通用化 6.借助开源库 golang-set 7.小结 参考文献 1.问题 如何判断元素是否切片中,Golang 并没有提供直接的库函数来判断...// ContainsInSlice 判断字符串是否 slice 中 func ContainsInSlice(items []string, item string) bool { for _,...查询元素是否 map 中的时间复杂度为 O(1)。 4.性能对比 我们可以看下在元素数量为 26 的情况下,取中位元素,做个基准测试(benchmark),对比下二者的查询性能。...),然后再判断某个 set 中是否存在某个元素。...mapset.NewSetFromSlice(sl) fmt.Println(s.Contains("m")) // true fmt.Println(s.Contains("mm")) // false } 7.小结 本文从问题“判断元素是否切片中

9K20

js判断元素在不在数组中_js判断数组是否为空

let res2 = arr.indexOf(3) // 验证是否包含:3 console.log(res2) // 结果:1 let res3 = arr.indexOf(4) // 验证是否包含...,indexOf 返回的是数组的下标,当没有包含时返回的是 -1 // 我们就可以通过这样的方式判断是否存在,判断结果是否大于 -1,大于则包含,不大于则不包含 let has = (arr.indexOf...function(value, index, arr) { return value > 2; }) console.log(find3) // 结果:3 // 我们发现 // 当数组中的元素测试条件时返回...true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。...// 如果没有符合条件的元素返回 undefined 3.findIndex函数 let arr = [2,3,4]; let findIndex = arr.findIndex(function(value

15.8K10

js判断数组中是否包含某元素的方法有哪些_js判断数组里面是否包含某个元素

find() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。...(v=>{ if(v === 查找值) { //则包含该元素 } }) 别的做法: js中存在一个数组,如何判断一个元素是否存在于这个数组中呢,首先是通过循环的办法判断,...代码如下: var arr = ['a','s','d','f']; console.info(isInArray(arr,'a'));//循环的方式 /** * 使用循环的方式判断一个元素是否存在于一个数组中...,不然是会报错的,另外,该方法某些版本的IE中是不起作用的,因此使用之前需要做一下判断,修改后的代码如下所示: /** * 使用indexOf判断元素是否存在于数组中 * @param {Object...,如果不存在与数组中,那么返回-1,代码如下所示: /** * 使用jquery的inArray方法判断元素是否存在于数组中 * @param {Object} arr 数组 * @param {Object

9.9K60

js判断数组中是否包含某个指定元素的个数_js 数组包含某个元素

,"Banana","Orange","Apple"]; var a = fruits.indexOf("Apple",4); // 6 注:string.indexOf()返回某个指定的字符串值字符串中首次出现的位置...该方法将从头到尾地检索字符串 stringObject,看它是否含有子串 searchvalue。开始检索的位置字符串的 fromindex 处或字符串的开头(没有指定 fromindex 时)。...find() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。...findIndex() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。...[NaN].indexOf(NaN) // -1 [NaN].findIndex(y => Object.is(NaN, y)) // 0 方法四:for() 遍历数组,然后 if 判断

10.9K30

js 判断数组是否包含某个元素方法集合的原因_怎么判断数组有几个元素

1、JavaScript indexOf() 方法 定义和用法 indexOf() 方法可返回某个指定的字符串值字符串中首次出现的位置。...说明 该方法将从头到尾地检索字符串 stringObject,看它是否含有子串 searchvalue。...Number类型 指定从数组的指定索引位置开始查找,默认为 0 3、JavaScript find() 方法 定义和用法 find() 方法返回通过测试(函数内判断)的数组的第一个元素的值。...find() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。...findIndex() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。

6.3K60

js 判断数组中是否包含某个元素(转载)「建议收藏」

find() 方法返回通过测试(函数内判断)的数组的第一个元素的值。...find() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。...findIndex() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。...的inArray方法判断元素是否存在于数组中 * @param {Object} arr 数组 * @param {Object} value 元素值 */ function isInArray2...,arr); if(index >= 0){ return true; } return false; 方法六、include()方法: arr.includes(searchElement)方法用来判断一个数组是否包含一个指定的值

16.4K30

如何用JS实现网页通过鼠标移动批量选择元素

鼠标移动,将选择框的大小(height、width)设置为鼠标移动的距离(起始点和终点的差) 鼠标抬起,停止选择框大小跟随鼠标移动,计算与选择框发生重叠的元素。...情形分析 网页元素重叠,存在多种不同的情况,针对每一种情况有不同的检测方法。...1.角重叠 角重叠,也就是选择框有至少一个角元素的范围内,或者元素至少有一个角选择框的范围内,此时可判断元素被选中。...角重叠 可以通过对选择框和元素进行相互检测,来判断元素是否选中,如图,判断一个点是否方形内的算法如下: 图例 //简单的判断 if ( X > X1 && X Y1 && Y < Y2 ) { return true; } 通过以上算法循环判断选择框的四个坐标点是否元素内,然后再判断元素的四个角是否选择框内,只要存在一个True,

4.2K60

Java中如何高效判断数组中是否包含某个元素

这是一个Java中经常用到的并且非常有用的操作。同时,这个问题在Stack Overflow中也是一个非常热门的问题。...投票比较高的几个答案中给出了几种不同的方法,但是他们的时间复杂度也是各不相同的。本文将分析几种常见用法及其时间成本。...实际,如果你需要借助数组或者集合类高效地检查数组中是否包含特定值,一个已排序的列表或树可以做到时间复杂度为O(log(n)),hashset可以达到O(1)。...3703useSet: 35183useLoop: 3218useArrayBinary: 14useArrayUtils: 3125 其实,如果查看ArrayUtils.contains的源码可以发现,他判断一个元素是否包含在数组中其实也是使用循环判断的方式...毕竟他可以让我少写很多代码(因为自己写代码难免有Bug,毕竟apache提供的开源工具类库都是经过无数开发者考验过的),而且,效率也并不低太多。

5.1K10

js判断数组中是否存在某个元素(四种方法)

法一:利用indexOf 不存在返回-1,存在返回第一次出现的索引 // js检查数组中是否包含某个元素 // 法一 indexOf var arr = [100,20,50,58,6,69,36,45,78,66,45...,直到找出第一个返回值为true的元素,然后返回该元素,否则返回undefined。...} }) console.log(param) 查找45,find会找出所有存在的45以及索引 法三:利用some some方法同样用于检测是否有满足条件的元素...用法与find相似,只是find是返回满足条件的元素,some返回的是一个Boolean值,从语义化来说,是否包含返回布尔值更贴切。...result) { //do something... }; console.log(result) 法四:includes ES6新增的数组方法,用于检测数组是否包含某个元素

6.9K40
领券