如何使用jquery打开选择输入

时间:2012-05-04 17:23:19

标签: javascript jquery select

所以我可以看到select元素的选项,但我需要点击它。如果我想使用某个功能怎么办?当发生某些事情时,应选择此选择元素,表示列表已打开,我可以看到选项。我不希望用户点击select元素,我想要其他东西来打开它。

我尝试了什么

$("select").select();
$("select").click();
$("select").focus();

有一个select元素,通常如果你想打开它(下拉列表),你点击它。如果我点击DIV或其他任何内容,我想要打开它。我希望打开此下拉列表,而无需用户单击select元素。

3 个答案:

答案 0 :(得分:22)

这应该有效:

var element = $("select")[0], worked = false;
if (document.createEvent) { // all browsers
    var e = document.createEvent("MouseEvents");
    e.initMouseEvent("mousedown", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
    worked = element.dispatchEvent(e);
} else if (element.fireEvent) { // ie
    worked = element.fireEvent("onmousedown");
}
if (!worked) { // unknown browser / error
    alert("It didn't worked in your browser.");
}

Example

答案 1 :(得分:5)

这里只是一个更新,因为接受的答案是正确但过时的,initMouseEvent很快就会被弃用。 [见:https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/initMouseEvent]

请改用以下内容:new MouseEvent [请参阅:https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/dispatchEvent]

示例代码:

var el = $('select'); // grab the input (jQuery)
var event = new MouseEvent('mousedown'); // create the event listener
el.dispatchEvent(event); // attach the event listener to the element

答案 2 :(得分:1)

我不认为您可以使用任何代码强制选择框drop down。但您仍然可以使用代码更改所选选项。请看这个

http://www.mredkj.com/tutorials/tutorial003.html