jquery - 将 jQuery 选择器应用于容器及其后代
问题描述
使用 jQuery,我可以轻松地找到/选择容器内与给定选择器匹配的所有元素:
$('.some_class', container);
但是如果我想包含容器本身,如果它与选择器匹配怎么办?
我认为以下方法可以解决问题。
$('.some_class', container).add($(container).filter('.some_class'));
但是有没有更简单的方法?理想情况下,我不必重复选择器。
预期行为
<div class="container common">
<div class="child common"></div>
</div>
下面的函数做我想要的,我只是想知道是否有一个更简单的解决方案。
function findInContainerAndDescendants(selector, $container) {
return $(selector, context).add($(context).filter(selector));
}
var $container = $('.container');
findInContainerAndDescendants('.common', $container) -> both container and child.
findInContainerAndDescendants('.child', $container) -> just the child.
解决方案
使用addBack() (jQuery >= 3.0)
或addSelf() (jQuery < 3.0)
:
function findInContainerAndDescendants(selector, context) {
return context.find(selector).addBack(selector);
}
见:https ://api.jquery.com/addBack/
添加看到这个小提琴:https ://jsfiddle.net/t8cy09vq/
推荐阅读
- php - Laravel AJAX NotFoundHttpException
- powershell - 调用 Workbook.Close() 函数将工作簿保存在所需位置
- c# - Winform中字体更改的标签留下痕迹
- android - Firebase 数据库未显示在列表视图中
- database - Cassandra - 按集群键搜索
- javascript - Scriptmanger.registerclientscript在下载文件c#时不起作用
- ios - 如何制作 - 自动完成搜索全局而不是本地
- python - Python:nlst() 使用 FTP_TLS 挂在“列表来了”
- django - 如何获取解码的 url 以在 Django 上下载文件?
- amazon-web-services - 如何启用 cognito 用户 MFA