11

所以我可以看到选择元素的选项,但我需要点击它。如果我想使用一个函数怎么办?当发生某些事情时,应该选择这个选择元素,这意味着列表是打开的,我可以看到选项。我不希望用户点击选择元素,我想要别的东西来打开它。

我试过的

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

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

4

3 回答 3

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.");
}

例子

于 2012-05-04T18:01:56.743 回答
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
于 2016-03-10T20:23:51.983 回答
1

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

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

于 2012-05-04T17:26:19.470 回答