所以我可以看到select元素的选项,但我需要点击它。如果我想使用某个功能怎么办?当发生某些事情时,应选择此选择元素,表示列表已打开,我可以看到选项。我不希望用户点击select元素,我想要其他东西来打开它。
我尝试了什么
$("select").select();
$("select").click();
$("select").focus();
有一个select元素,通常如果你想打开它(下拉列表),你点击它。如果我点击DIV
或其他任何内容,我想要打开它。我希望打开此下拉列表,而无需用户单击select元素。
答案 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.");
}
答案 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
。但您仍然可以使用代码更改所选选项。请看这个