多个 If 语句相互抵消?(Javascript)
Multiple If Statements Cancelling each-other out? (Javascript)
我在一段需要多行"if"逻辑来处理功能的代码时遇到了一些麻烦。
其中两个 if 语句做同样的事情,在我看来,有些是相互抵消的。
function visibleCheck() {
var target = document.getElementById('contentType').val();
if (target != "BYOC - Document to Exam") {
document.getElementById('VideoMinutes').style.display = 'block';
}
else document.getElementById('VideoMinutes').style.display = 'none';
if ((target != "Custom Production - Avatar") {
document.getElementById('Questions').style.display = 'block';
}
else document.getElementById('Questions').style.display = 'none';
if ((target != "Custom Production - Video") {
document.getElementById('Questions').style.display = 'block';
}
else document.getElementById('Questions').style.display = 'none';
}
第一个 if 语句运行良好。第二个似乎根本没有运行。第三个运行良好。
如果我重新订购第二个和第三个交换位置,新的第二个将不起作用。
如果我使用 or 运算符"||"并组合语句,它根本不起作用。
无论 if 语句的条件如何,第三条语句始终有效。
如果我同时进行第二个和第三个 if 或语句,那么两者都不起作用。
有什么想法吗?
我正在销售队伍的视觉力量页面上使用它,如果这有什么不同的话。
首先,请注意,DOMElements 没有 val()
方法,该方法仅适用于 jQuery 对象。应使用 value
属性。
其次,逻辑是有缺陷的,因为Questions
元素的执行可以通过多个相互矛盾的条件流动。试试这个:
function visibleCheck() {
var target = document.getElementById('contentType').value;
if (target != "BYOC - Document to Exam") {
document.getElementById('VideoMinutes').style.display = 'block';
}
else {
document.getElementById('VideoMinutes').style.display = 'none';
}
if (target != "Custom Production - Avatar" && target != "Custom Production - Video") {
document.getElementById('Questions').style.display = 'block';
}
else {
document.getElementById('Questions').style.display = 'none';
}
}
当你用jQuery标记它时,这里有一个简化的jQuery版本:
function visibleCheck() {
var target = $('#contentType').val();
$('#VideoMinutes').toggle(target != 'BYOC - Document to Exam');
$('#Questions').toggle(target != "Custom Production - Avatar" && target != "Custom Production - Video");
}
相关文章:
- 为什么不't Javascript对我的输入值进行了一些重新检查
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 使用php或javascript从facebook相册URL中删除多余的部分
- 正在添加'X'按钮,在文本字段旁边使用javascript
- 如何在JavaScript中将字符串转换为函数引用
- 模糊事件的Javascript测试
- Javascript更改图标
- 如何将HTML id分配给元素,以及如何将JavaScript应用于元素
- 如何使用WCF服务和javascript表单post上传.doc文件
- javascript结合了数组和字典
- 这是什么 ==- javascript 运算符
- 从javascript创建一个列表
- 无法在通过jQuery的ajax加载的页面中执行javascript
- Javascript:selenium Web驱动程序isDisplayed()不工作
- 如何通过ajax刷新JSF填充的javascript变量
- Javascript - 覆盖新的 Date() 行为以抵消 GMT
- 多个 If 语句相互抵消?(Javascript)
- 为什么我的window.onload代码会抵消我的其他javascript
- 在JavaScript中调整窗口滚动位置以抵消上面元素的大小调整