select下拉框添加onchange事件获取option的value值的方法

本文介绍两种在HTML中为select下拉框添加onchange事件以获取option的value值的方法。方法一直接通过事件属性传值,方法二则通过访问options对象获取选中项的值。

这里介绍两种select下拉框添加onchange事件获取option的value值的方法:

方法一:

HTML

   <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>select onchange 传值</title>
    </head>
    <body>
        <select  onchange="getSelectValue(this.value)">
            <option value="北京">北京</option>
            <option value="上海">上海</option>
            <option value="广州">广州</option>
            <option value="深圳">深圳</option>
        </select>
    </body>
    </html>

​

​

方法二:

HTML

​
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>select onchange 传值</title>
    </head>
    <body>
        <select  onchange="getSelectValue(this.options[this.options.selectedIndex].value)">
            <option value="北京">北京</option>
            <option value="上海">上海</option>
            <option value="广州">广州</option>
            <option value="深圳">深圳</option>
        </select>
    </body>
    </html>

​

​

JS

function getSelectValue(val){
    alert(val);     
}   

 

`onselectend` 事件通常用于文本框等可编辑元素,当用户结束选择文本时触发,而 `select` 下拉框并不适合使用 `onselectend` 事件获取选中,`select` 下拉框一般使用 `onchange` 事件获取选中。不过,如果非要模拟类似 `onselectend` 的行为,可以借助 `mousedown` 和 `mouseup` 等事件来实现。 ### 使用 `onchange` 事件获取 `select` 下拉框选中 以下是使用 `onchange` 事件的示例代码: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> </head> <body> <select id="mySelect" onchange="getSelectedValue()"> <option value="option1">选项1</option> <option value="option2">选项2</option> <option value="option3">选项3</option> </select> <script> function getSelectedValue() { var selectElement = document.getElementById('mySelect'); var selectedValue = selectElement.value; console.log('选中的是: ' + selectedValue); } </script> </body> </html> ``` 在上述代码中,当 `select` 下拉框的选中项发生变化时,会触发 `getSelectedValue` 函数,该函数通过 `selectElement.value` 获取选中项的并打印到控制台。 ### 模拟 `onselectend` 行为获取 `select` 下拉框选中 以下是模拟 `onselectend` 行为的示例代码: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> </head> <body> <select id="mySelect2"> <option value="option1">选项1</option> <option value="option2">选项2</option> <option value="option3">选项3</option> </select> <script> var selectElement2 = document.getElementById('mySelect2'); var isClicking = false; selectElement2.addEventListener('mousedown', function () { isClicking = true; }); selectElement2.addEventListener('mouseup', function () { if (isClicking) { var selectedValue = this.value; console.log('选中的是: ' + selectedValue); isClicking = false; } }); </script> </body> </html> ``` 在这段代码中,通过监听 `mousedown` 和 `mouseup` 事件来模拟 `onselectend` 的行为,当鼠标按下时标记为正在点击,鼠标松开时获取选中并打印到控制台。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值