使用 javascript onchange 的下拉菜单

IT技术 javascript onchange
2021-02-23 17:10:21

我有一个简单的下拉菜单,我想拥有它,以便如果用户选择“生孩子”,消息将更改为“生孩子”,但对于任何其他选择。消息保持不变(没有),但这不起作用。有人可以帮忙吗。请玩我的 jsfiddle。

http://jsfiddle.net/Z9YJR/ 这是 html

<select id="leave">
  <option value="5">Get Married</option>
  <option onchange="changeMessage()" value="100">Have a Baby</option>
  <option value="90">Adopt a Child</option>
  <option value="15">Retire</option>
  <option value="15">Military Leave</option>
  <option value="15">Medical Leave</option>
</select>

<div id="message"></div>

这是js

function changeMessage() {
    document.getElementById("message").innerHTML = "Having a Baby!!";
}
3个回答

这样的事情应该可以解决问题

<select id="leave" onchange="leaveChange()">
  <option value="5">Get Married</option>
  <option value="100">Have a Baby</option>
  <option value="90">Adopt a Child</option>
  <option value="15">Retire</option>
  <option value="15">Military Leave</option>
  <option value="15">Medical Leave</option>
</select>

<div id="message"></div>

Javascript

function leaveChange() {
    if (document.getElementById("leave").value != "100"){
        document.getElementById("message").innerHTML = "Common message";
    }     
    else{
        document.getElementById("message").innerHTML = "Having a Baby!!";
    }        
}

jsFiddle 演示

更短的版本和更通用的可能是

HTML

<select id="leave" onchange="leaveChange(this)">
  <option value="5">Get Married</option>
  <option value="100">Have a Baby</option>
  <option value="90">Adopt a Child</option>
  <option value="15">Retire</option>
  <option value="15">Military Leave</option>
  <option value="15">Medical Leave</option>
</select>

Javascript

function leaveChange(control) {
    var msg = control.value == "100" ? "Having a Baby!!" : "Common message";
    document.getElementById("message").innerHTML = msg;
}
抱歉,错过()onchange=leaveChange
2021-04-20 17:10:21
您可以将选择对象传递到函数中以获得更大的抽象... onchange="leaveChange(this)"... function leaveChange(elem){ if(e.value...
2021-05-05 17:10:21

它不起作用,因为您在 JSFiddle 中的脚本正在它自己的范围内运行(请参阅左侧的“OnLoad”下拉菜单?)。

解决此问题的一种方法是在 javascript 中绑定您的事件处理程序(它应该在哪里):

document.getElementById('optionID').onchange = function () {
    document.getElementById("message").innerHTML = "Having a Baby!!";
};

另一种方法是修改 fiddle 环境的代码并显式声明您的函数为全局函数,以便您的内联事件处理程序可以找到它:

window.changeMessage() {
    document.getElementById("message").innerHTML = "Having a Baby!!";
};

简单

<script>
jQuery.noConflict()(document).ready(function() {
    $('#hide').css('display','none');
    $('#plano').change(function(){

        if(document.getElementById('plano').value == 1){
            $('#hide').show('slow');    

        }else 
            if(document.getElementById('plano').value == 0){

             $('#hide').hide('slow'); 
        }else
            if(document.getElementById('plano').value == 0){
             $('#hide').css('display','none');  

            }

    });
    $('#plano').change();
});
</script>

如果在组合框中选择某个特定值,此示例将显示和隐藏 div

因为显然每个有 javascript 问题的人都使用或想要使用 jQuery!
2021-05-12 17:10:21