首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS和JQuery获取当前元素的兄弟及父级等元素的方法

) jQuery.parents(expr),类似于 jQuery.parents(expr) ,但是是查找所有祖先元素,不限于父元素 jQuery.children(expr),返回所有子节点,这个方法只会返回直接的孩子节点...,而 jQuery.find(),的返回结果,不会有初始集合中的内容,比如 $("p").find("span") ,是从 元素开始找 ,等同于 $("p span") JS获取:...var chils= s.childNodes;  //得到s的全部子节点 var par=s.parentNode;   //得到s的父节点 var ns=s.nextSibling;   //获得...;   //获得s的最后一个子节点 JS获取节点父级,子级元素:JS的方法会比JQUERY麻烦很多,主要则是因为FF、谷歌浏览器会把你的换行也当作DOM元素:空的text元素,目前IE也是这样       原生的JS获取ID为test的元素下的子元素。

12.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS获取节点的兄弟,父级,子级元素的方法

    2015-08-18 03:48:27 下面介绍JQUERY的父,子,兄弟节点查找方法 jQuery.parent(expr)  找父亲节点,可以传入expr进行过滤,比如$("span").parent...()或者$("span").parent(".class") jQuery.parents(expr),类似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素 jQuery.children...这个方法和children()的区别就在于,包括空白文本,也会被作为一个 jQuery对象返回,children()则只会返回节点 jQuery.prev(),返回上一个兄弟节点,不是所有的兄弟节点 jQuery.prevAll...(),返回所有之前的兄弟节点 jQuery.next(),返回下一个兄弟节点,不是所有的兄弟节点 jQuery.nextAll(),返回所有之后的兄弟节点 jQuery.siblings(),返回兄弟姐妹节点...jQuery.filter()是从初始的jQuery对象集合中筛选出一部分,而jQuery.find()的返回结果,不会有初始集合中的内容,比如$("p"),find("span"),是从元素开始找

    9.2K10

    准确获取事件源的任意父级元素(事件委托)

    通常我们都会使用事件源e.target来获取点击的元素,从而可以知道我们点击的是谁。...需要实现的功能是,点击这个盒子区域,输出对应的li对应的id,下面是这个li对应的代码片段,很显然在li内部存在着大量的子元素,我们需要通过给li的父元素ul绑定事件,从而实现事件委托,那么我们该如何确定我们点击的元素属于哪一个...li了,从而导致我们获取不到id无从下手 解决方法 下面我通过另一种方法很好的解决了这个问题 在我们的事件对象event中,存在着一个方法path,这个方法可以返回事件触发的所有父元素,我们可以使用这个方法...我们先通过e.path获取到事件触发对象的所有的所有元素,这个方法的返回值是一个数组,我们可以通过数组中的find方法按照我们的需求选择我们想要的元素,在下面的代码中,我们先给每一个li添加一个特有的标志属性...,整个方法的核心就是通过获取到触发事件元素的所有父元素集合,再通过筛选从而获得元素!

    2.6K30

    jquery中动态新增的元素节点无法触发事件解决办法

    在使用jquery中动态新增的元素节点时会发现添加的事件是无法触发的,我们下面就为各位来详细的介绍此问题的解决办法.   ...其实最简单的方法就是直接在标签中写onclick="",但是这样写其实是有点low的,最好的方式还是通过给类名绑定一个click事件。...解决jquery中动态新增的元素节点无法触发事件的问题有两种解决方法,如下: 方法一:使用live   live()函数会给被选的元素绑定上一个或者多个事件处理程序,并且规定当这些事件发生时运行的函数。...通过live()函数适用于匹配选择器的当前及未来的元素。比如,通过脚本动态创建的元素。...实现如下: $('.liLabel').live('click', function(){ alert('OK'); }); 方法二:使用on   可以通过on方法绑定事件,可以绑定到它的父级或者

    1.7K20

    jQuery事件委托

    在jQuery中,事件委托是一种优化事件处理的技术,它利用事件冒泡的机制,将事件处理程序绑定到一个父级元素上,从而减少事件处理函数的数量,并实现对动态添加的子元素的事件处理。什么是事件委托?...事件委托是一种将事件处理程序绑定到父级元素上的技术,它利用事件冒泡机制,当子元素触发事件时,事件会冒泡到父级元素,从而触发绑定在父级元素上的事件处理程序。...使用事件委托有以下几个好处:减少事件处理函数的数量:通过将事件处理程序绑定到父级元素上,我们无需为每个子元素都绑定事件处理程序,从而减少了事件处理函数的数量,使代码更加简洁和可维护。...提高性能:由于事件委托将事件处理程序绑定到父级元素上,避免了为每个子元素都绑定事件处理程序的开销,从而提高了性能。如何使用事件委托?在jQuery中,我们可以使用on()方法结合选择器来实现事件委托。...事件委托的优点和适用场景事件委托有以下优点:减少事件处理函数的数量,提高代码的可维护性和性能。可以处理动态添加的元素,无需手动重新绑定事件处理程序。可以统一管理事件处理程序,使代码更加简洁和易于维护。

    1.1K10

    【震惊】padding-top的百分比值参考对象竟是父级元素的宽度

    */ width: 100vw; /* calc方法动态计算:height的值为宽度的1/2,所以是 (100vw - 20px) / 2 */ height: calc...探究padding-top的秘密 当padding-top的值为百分比时,参考的对象是父级元素的宽度 这句话圈起来,是重点,要考~ <!....a { /* 设置margin左右间距为10px */ margin: 0 10px; background: #F00; /* 设置宽度为100%,父级容器宽度的...100%,实际宽度会受到弹性盒子的影响 */ width: 100%; height: 0; /* calc方法动态计算:padding-top的值为父级容器宽度的1...最后的秘密 当padding-top、padding-bottom、margin-top、margin-bottom属性设置为百分比时,参考对象都是父级元素的宽度 要记住呀,下回还得考~ 以上就是胡哥今天给大家分享的内容

    1.7K10

    jQuery中on()、bind()、live()、delegate()之间的区别

    事件冒泡 当我们点击一个链接时,其触发了链接元素的单击事件,该事件则引发任何我们已绑定到该元素的单击事件上的函数的执行。...click事件接着会向树的根方向传播,广播到父元素,然后接着是每个祖先元素,只要是它的某个后代元素上的单击事件被触发,事件就会传给它。 ? 在操纵DOM的语境中,document是根节点。...; }); 当我们在a 上面点击的时候,首先会触发它本身所绑定的click事件,然后会一路往上,触发它的父元素,祖先元素上所有绑定的click事件。...它会绑定事件到所有的选出来的元素上 它不会绑定到在它执行完后动态添加的那些元素上 当元素很多时,会出现效率问题 当页面加载完的时候,你才可以进行bind(),所以可能产生效率问题 2 .live()...data来决定那个子元素来匹配,但是因为你可以决定放在那个根元素上,所以可以有效的减小你所要查找的元素 可以用在动态添加的元素上 缺点 需要查找那个那个元素上发生了那个事件了,尽管比document少很多了

    1.3K30

    杨老师课堂之Jquery的筛选,事件,效果,Ajax,javascript跨域)

    offsetParent(),返回第一个匹配元素用于定位的父节点。 •这返回父元素中第一个其position设为relative或者absolute的元素。此方法仅对可见元素有效。...可以在父元素上检测子元素获取焦点的情况。...可以用同样的方法解决 元素上的问题 阻止默认行为 网页中的元素都有自己默认的行为,例如:单击超链接后悔跳转,单击”提交”按钮会表单会提交,有时需要阻止元素的默认行为 在jquery中,提供了preventDefault...jquery对其进行了封装,使之能兼容各大浏览器 (3)event.stopPropagation()方法 阻止事件的冒泡.js真符合W3C规范的stopPropagation()方法在IE浏览器中无效....jquery 对其进行了封装,使之能兼容各大浏览器 (4) event.target()方法 event.target()方法的作用是获取到触发事件的元素.jquery对其封装后,避免了 W3C,IE

    8.3K20

    块元素, 内联元素, 内联块元素块元素(默认为父级宽度的100%,支持全部样式):内联元素(不支持宽高, 不支持margin上下, 不支持padding上下)内联块元素(从其它元素转换而来, disp

    块元素(默认为父级宽度的100%,支持全部样式): body h1 , h2, h3, h4, h5, h6 p div li (条目) ul(定义无序列表, 子标签li, 带点号) ol(定义有序列表...雪碧 可乐 凉茶 Python python是一门高级的动态语言 C C是一门古老的静态语言 内联元素(不支持宽高, 不支持margin上下, 不支持padding上下) a span em(语气强调...,斜体) i(专业词汇, 斜体) b(关键词, 加粗) strong(非常重要, 加粗) input(输入框, 支持全部样式) img(图片, 支持全部样式) 间隙问题: 父级设置字体为0, 子级单独设置字体尺寸...) 没有原生的内联块元素 任何元素都可以转换为内联块元素 display: inline-block(内联块元素) inline(内联元素) block(块元素) none(隐藏)

    1.2K60

    Java学习日记

    网页是由块级元素和行内元素堆叠成的,块级元素的实质是行内元素的首尾增加了一个换行符,所以块级元素的默认 布局是从上到下排序的;而行内元素是从左到右的默认排序,默认的元素之间的排列是有间隙的,可以通过的设置元...锚标记(a标签):建议写动态获取服务器地址的绝对路径, 例如:${pageContext.request.contextPath}:作用就是动态的获取服务器里的项目地址。2....全选功能:这里要用到label标签的for属性,关联表单的输入复选框,当单击全选按钮功能的时候 所有权限的功能都要选上,实现方式就是给该标签元素实现单击事件,完成全选的功能 用的选择器使用JQuery实现的...选择子权限时,父权限也要勾选     else/否则当前的元素不被选中/3. 取消选择所有的子权限时,父级权限也被取消if() );    ....闭包的实质就是延长局部依赖的变量的生命 周期,使之达到和全局依赖的变量效果是一样的。

    60740

    JQuery高级

    jQuery中定义变量的时候,一般命名用$开头。同事一看就知道是使用了jQuery,然后使用jQuery的语法。 其实$是jQuery中的一个函数。...***事件冒泡 现象:父子级标签 触发子级的事件,这个事件会逐层向父级传递。 子集执行了某一事件,会逐层向上触发相同事件,直到被处理或者遇到return。...比如子级有单击事件,那么父级如果有单击事件也会被触发,父级的父级如果有单击事件也会被触发。 任何一个操作,计算机或者浏览器都会去处理。不管你有没有设置对应的事件。...body> 1 3.事件委托 把子级的事件委托给父级...(父:最近的能包含住将来发生事件的所有子级)------ 事件代理 .delegate(真实发生事件的目标,字符串事件属性,匿名函数去写命令function(){}) 工作中有可能会有人用这个词on()

    1.5K50

    jquery 事件冒泡、阻止事件冒泡 - event.stopPropagation()

    什么是事件冒泡 在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播...,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window)。...事件冒泡的作用 事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父级元素上,避免把事件处理器添加到多个子级元素上),它还可以让你在对象层的不同级别捕获事件。...好了,现在黄色的div已经跟两个父级的元素位置不重叠了。再次点击看看,如下: ? ? ? 事件冒泡示例的结论 可以看出点击黄色div,依然会依次弹出三个alert()。...使用return false;其实就是使函数传递false的值,从而阻止冒泡传递,阻止函数继续执行。

    6.1K41
    领券