- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在向页面动态添加 Collapsable 元素。 Bootstrap 使用“data-target”属性来指定折叠切换适用于哪个元素。
来自文档:
The data-target attribute accepts a css selector
有没有办法编写一个选择器来指定父元素的下一个兄弟元素?文档中的所有示例似乎都使用按 ID 进行选择。
具体来说,HTML 看起来像这样:
<div class="accordion-group">
<div class="accordion-heading">
<a class="accordion-toggle" data-toggle="collapse" data-target="#collapseOne">
Generated Title
</a>
</div>
<div id="collapseOne" class="accordion-body collapse in">
<div class="accordion-inner">
Generated Content... this is big and sometimes needs collapsing
</div>
</div>
</div>
我想写这样的东西(非法使用 jquery 语法的伪代码):
<a class="accordion-toggle" data-toggle="collapse" data-target="$(this).parent().next()">
但我开始怀疑这可能无法通过 CSS 选择器实现。
现在,作为解决方法,我在创建元素时生成一个新 ID(附加到字符串的递增数字)。
是否有使用选择器的更好方法?我应该使用一些创建后的 javascript 来设置数据目标属性吗?为动态内容生成 ID 是标准方法吗?
最佳答案
虽然 data-target
属性中的选择器确实是一个 jQuery 选择器,但是这个插件的 data-api 规范没有提供引用回 this
的方法> 在执行范围内(参见 lines 147-153 in bootstrap-collapse.js 的使用)。
但是,我想提供另一种替代方法,即使用您自己的自定义切换说明符扩展数据 API。我们称之为collapse-next。
$('body').on('click.collapse-next.data-api', '[data-toggle=collapse-next]', function (e) {
var $target = $(this).parent().next()
$target.data('collapse') ? $target.collapse('toggle') : $target.collapse()
})
<a class="accordion-toggle" data-toggle="collapse-next">
这里的缺点是它是一种相当紧密耦合的方法,因为 JS 假定标记的特定结构。
作为@slhck pointed out in his answer , IE9 及以下版本在使用我的答案的较早版本时显然在第一次点击时失败。原因实际上根本不是 IE 问题,而是 Bootstrap 问题。如果在 Carousel
对象未初始化的目标上调用 .collapse('toggle')
,则 toggle()
方法将被调用两次 -在初始化期间一次,然后在初始化后再次明确。这绝对是一个 Bootstrap 错误,希望能得到修复。它在 Chrome、FF、IE10 等中没有出现的唯一原因是因为它们都支持 CSS 转换,因此当第二次调用时它会短路,因为第一次调用一个仍然活跃。上面更新的解决方法只是通过首先检查初始化并以不同方式处理它来避免双重调用问题。
关于javascript - 您可以为 Bootstrap 指定一个 "data-target"来引用同级 DOM 元素而不使用 ID 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12805825/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: template pass by value or const reference or…? 以下对于将函数
我用相同的参数列表重载了一个运算符两次。但返回类型不同: T& operator()(par_list){blablabla} const T& operator()(par_list){bla
假设我有实现接口(interface) I 的 Activity A。我的 ViewModel 类 (VM) 持有对实现接口(interface) I 的对象的引用: class A extends
PHP 如何解释 &$this ?为什么允许? 我遇到了以下问题,这看起来像是 PHP 7.1 和 7.2 中的错误。它与 &$this 引用和跨命名空间调用以及 call_user_func_arr
谁能解释一下下面“&”的作用: class TEST { } $abc =& new TEST(); 我知道这是引用。但是有人可以说明我为什么以及什么时候需要这样的东西吗?或者给我指向一个对此有很好解
引用变量是一个别名,也就是说,它是某个已存在变量的另一个名字。一旦把引用初始化为某个变量,就可以使用该引用名称或变量名称来指向变量。 C++ 引用 vs 指针 引用很容易与指针混淆,它们之间有三
目录 引言 背景 结论 引言 我选择写C++中的引用是因为我感觉大多数人误解了引用。而我之所以有这个感受是因为我主持过很多C++的面试,并且我很少
Perl 中的引用是指一个标量类型可以指向变量、数组、哈希表(也叫关联数组)甚至函数,可以应用在程序的任何地方 创建引用 定义变量的时候,在变量名前面加个 \,就得到了这个变量的一个引用 $sc
我编写了一个将从主脚本加载的 Perl 模块。该模块使用在主脚本中定义的子程序(我不是维护者)。 对于主脚本中的一个子例程,需要扩展,但我不想修补主脚本。相反,我想覆盖我的模块中的函数并保存对原始子例
我花了几个小时试图掌握 F# Quotations,但我遇到了一些障碍。我的要求是从可区分的联合类型中取出简单的函数(只是整数、+、-、/、*)并生成一个表达式树,最终将用于生成 C 代码。我知道使用
很多时候,问题(尤其是那些标记为 regex 的问题)询问验证密码的方法。似乎用户通常会寻求密码验证方法,包括确保密码包含特定字符、匹配特定模式和/或遵守最少字符数。这篇文章旨在帮助用户找到合适的密码
我想通过 MIN 函数内的地址(例如,C800)引用包含文本的最后一个单元格。你能帮忙吗? Sub Set_Formula() ' ----------------------------- Dim
使用常规的 for 循环,我可以做类似的事情: for (let i = 0; i < objects.length; i++) { delete objects[i]; } 常规的 for-
在 Cucumber 中,您定义了定义 BDD 语法的步骤;例如,您的测试可能有: When I navigate to step 3 然后你可以定义一个步骤: When /^I navigate t
这是什么UnaryExpression的目的,以及应该怎样使用? 最佳答案 它需要一个 Expression对象并用另一个 Expression 包裹它.例如,如果您有一个用于 lambda 的表达式
给出以下内容 $("#identifier div:first, #idetifier2").fadeOut(300,function() { // I need to reference jus
我不知道我要找的东西的正确术语,但我要找的是一个完整的引用,可以放在双引号之间的语句,比如 *, node()、@* 以及所有列出的 here加上任何其他存在的。 我链接到的答案提供了一些细节,但还
This question's answers are a community effort。编辑现有答案以改善此职位。它当前不接受新的答案或互动。 这是什么? 这是常见问答的集合。这也是一个社区Wi
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
考虑下一个代码: fn get_ref(slice: &'a Vec, f: fn(&'a Vec) -> R) -> R where R: 'a, { f(slice) } fn m
我是一名优秀的程序员,十分优秀!