- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
老实说,我对 jquery 和 javascript 还很陌生,我在使用复选框时遇到了麻烦。
这是因为 #checkAll 是一个复选框,用于检查所有其他具有“check”类的复选框:
function test() {
if($("#checkAll").prop('checked')) {
$(".check").prop('checked', true);
} else {
$(".check").prop('checked', false);
}
}
但是,我希望它在我选中任何复选框时起作用。所以我尝试将函数作为点击事件放在所有复选框中,只使用 onclick="test()"。
我认为问题在于我正在尝试使用 $(this) 但我一定是错误地使用了它,我所拥有的是:
function test() {
if($(this).prop("checked")) {
$(".check").prop("checked", true);
} else {
$(".check").prop("checked", false);
}
}
“$(this)”也有类“check”,所以可能与此有关。
最终我想选中一个复选框,它会选中所有之前的复选框,而不是之后出现的复选框。我想如果我明白为什么这不起作用,那么我应该能够弄清楚。我不懒惰,只是在学习!!
我已经搜索过答案,但找不到。我希望有人能提供帮助。
提前致谢!
最佳答案
当您执行 onclick="test()"
时,您会在全局上下文中调用 test()
,因此 this
将设置为 window
,而不是您的 DOM 元素。您可以通过多种方式解决此问题。
你可以 D4V1D's solution , 传递一个参数。
您还可以使用 test.call(this)
手动强制上下文成为 DOM 元素。
您还可以通过 jQuery 而不是作为属性附加事件处理程序:
$(".check").click(test);
jQuery 将使用正确的上下文自动调用回调。
顺便说一句,我建议你看看prevAll
下一步要做什么。
关于javascript - 检查当前和以前的复选框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29329318/
我是 firebase 的新手,我正在尝试分页查询。我喜欢有一个“下一个”和“上一个”按钮。我的下一个按钮工作正常,我的问题是单击上一个 引用:https://firebase.google.com/
抱歉,标题这么蹩脚,但我只是不知道该放什么,希望你能理解。另外,我不知道以前是否有人问过类似的问题,因为我不知道合适的关键字 - 因此也无法用谷歌搜索。 基本上...在查看preg_match_all
我想在 TFS 中 check out 一个检入文件的先前版本。我可以轻松获得特定文件的变更集 ID 列表,但无法弄清楚如何 checkout 以前的版本。 我目前的代码: var workspace
我想使用 @FunctionalInterface来 self 代码中的 Java 8,但我希望能够将生成的类文件与 Java 6 一起使用。我认为我应该将源版本设为 1.8 , 目标版本为 1.6
自从 versions 被删除以来,我一直无法找到安装以前版本软件的方法。命令并点击 Homebrew。我在 2008 Mac Pro (3,1) 上运行 macOS 10.14.3 (Mojave)
当我开始当前的项目时,App Store 中已经有一个应用程序。此应用程序仅适用于 iPhone。 我的第一个任务是测试和构建一个也可以在 iPod Touch 上运行的版本。 大约 3 周前,App
我在 GitHub 上有一个曾经是 fork 的 repo,但现在不是了,因为我已经删除了原始项目的任何痕迹并开始了一个同名的新项目。 但是,GitHub 仍然表示该项目是 fork 的。有什么方法可
我是一名优秀的程序员,十分优秀!