javascript - 在 dropbox 中更改选项时更改 div 的可见性

标签 javascript html

我的 php 中有这样的代码:

<section id="placeOrder">
<h2>Place order</h2>
Your details
Customer Type: 
<select name="customerType">
    <option value="">Customer Type?</option>
    <option value="ret">Customer</option>
    <option value="trd">Trade</option>
</select>

这些是必须根据所选选项更改其可见性的 div:

<div id="retCustDetails" class="custDetails">
    Forename <input type="text" name="forename" id="forename" />
    Surname <input type="text" name="surname" id="surname" />
</div>
<div id="tradeCustDetails" class="custDetails" style="visibility:hidden">
    Company Name <input type="text" name="companyName" id="companyName" />
</div>

我试过这个javascript:

<script>
document.getElementsByName("customerType").onchange = function () {
    var val = this.options[this.selectedIndex].value;
    document.getElementById("tradeCustDetails").style.visibility = (val == "trd") ? "visible" : "hidden";
    document.getElementById("retCustDetails").style.visibility = (val == "trd") ? "hidden" : "visible";
};
</script>

但是 div tradecustdetails" 没有出现并且 div retCustDetails 仍然在那里。

有人能帮忙吗?

最佳答案

getElementsByName() 返回文档中具有指定名称的所有元素的集合。因此你必须像这样遍历它们:

var x = document.getElementsByName("customerType");
for (var i = 0; i < x.length; i++) {
    // do something with x[i]
}

如果您只使用一个选择元素,那么最好像这样使用 getElementById():

HTML

<select id="customerType" name="customerType">
    <option value="">Customer Type?</option>
    <option value="ret">Customer</option>
    <option value="trd">Trade</option>
</select>

脚本

document.getElementById("customerType").onchange = function () {
    var val = this.options[this.selectedIndex].value;
    document.getElementById("tradeCustDetails").style.visibility = (val == "trd") ? "visible" : "hidden";
    document.getElementById("retCustDetails").style.visibility = (val == "trd") ? "hidden" : "visible";
};

关于javascript - 在 dropbox 中更改选项时更改 div 的可见性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36445735/

相关文章:

html - Firefox 缩放自己的网站

javascript - 正则表达式删除 Javascript 中的 &lt;script&gt; 及其内容

javascript - 如何在 Nest.js 中使用查询参数?

php - 将 Youtube 链接添加到 php 循环中的 slider

javascript - 如何使用 addEventListener(webkitTransitionEnd) 在 window.close() 之前延迟?

javascript - jQuery : How To Get src Value of Multiple img

javascript - 如何将正则表达式与字符串变量连接?

javascript - 带有散列密码的 php 代码无法工作

javascript - 过渡效果不起作用jquery

javascript - 为什么我的简单邮件 php 表单需要很长时间才能加载?