- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我发现时,我正在使用 JQuery 对 DIV 进行一些动态效果this.id
的返回值因函数而异。
我有两组简单的父子 DIV 标签,如下所示:
<DIV ID="row">
<DIV ID="c1">
<Input type="radio" name="testing" id="testing" VALUE="1">testing1
</DIV>
</DIV>
<DIV ID="row">
<DIV ID="c2">
<Input type="radio" name="testing" id="testing" VALUE="2">testing2
</DIV>
</DIV>
代码1。
$('#row DIV').mouseover(function(){
radio_btns.each(function() {
$('#row DIV).addClass('testing'); // worked
});
});
代码2。
$('#row DIV').mouseover(function(){
var childDivID = this.id;
radio_btns.each(function() {
$('#'+childDivID).parent('DIV').addClass('testing'); // didn't work
});
});
我不明白为什么只有第一个代码可以工作
并突出显示所有“行”DIV,
但第二个代码未能做到这一点?
最佳答案
首先,您多次使用相同的 ID,这会导致各种奇怪的行为,因为它是无效的 HTML。
纠正此问题后,对于第二个代码示例,您需要进行调整以突出显示悬停时的当前行(注意 .row
现在是一个类以消除 ID 问题),like this :
$('.row div').mouseover(function(){
$('#'+this.id).parent('div').addClass('testing');
});
但是,有一种更好的方法可以解决此问题,因为您已经拥有对该对象的引用 like this :
$('.row div').mouseover(function(){
$(this).addClass('testing');
});
一般来说,如果您有 this
,我想不出您想要使用 $("#"+this.id)
的情况,应该是 $(this)
来获取你想要的 jQuery 对象。
还有一个项目,实际上是在问题之外,如果您想在这种情况下悬停,请使用 .hover()
和 .toggleClass()
, like this :
$('.row div').hover(function(){
$(this).toggleClass('testing');
});
关于jquery - this.id 到底是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2836915/
这对你们来说可能很简单,但由于我是java新手,所以我想知道实际上什么是 接下来的部分会发生什么? if (args.length > 0) { file = args[0]; } publi
在我的 View Controller 中,我将 UITapGestureRecognizer 添加到 self.view。我在 self.view 之上添加了一个小 View 。当我点击小 View
我今天尝试从 Obj-C 开始并转到 Swift,我正在阅读文档。我试图在 Swift 中创建一个简单的 IBOutlet,但它不断给我这些错误。 View Controller 没有初始化器 req
我正在尝试使用 VIM 完成(字典和当前缓冲区),但我遇到了问题?和 !在方法名称的末尾。我能以某种方式向 vim 解释方法名称(基本上是单词)最后只能有它,而且只有一个,即 method_name
我是一名优秀的程序员,十分优秀!