gpt4 book ai didi

javascript - 如何通过双击下拉列表提交值?

转载 作者:行者123 更新时间:2023-11-28 02:40:25 28 4
gpt4 key购买 nike

我正在寻找一种使用 Greasemonkey 在下拉列表 ( which is auto-sized ) 中单击两次来提交值的方法。

目标 HTML:

<form method="post">
<select size="3" name="z_pos_id">
<option value="2463">Option A</option>
<option value="2609">Option B</option>
<option value="3013">Option C</option>
</select>
<input type="submit" value="Button">
</form>

此时,我单击选项将其选中,然后单击按钮提交值(按 Enter 也可以)。

但是对于 Greasemonkey 脚本,我想单击选项来选择它,然后再次单击所选选项来提交它。这可能吗?

最佳答案

处理两次左键单击而不干扰中心单击和右键单击(太多)的一种方法是:

  1. 跟踪是否 <option>mousedown时被选择事件触发。
  2. 确保稍后触发鼠标单击事件时它仍处于选中状态。
  3. 如果两个条件都满足,请提交包含的表单。

为了大大简化代码,这次使用了 jQuery。 See the code in action at jsFiddle.

一个完整的脚本看起来像这样:

// ==UserScript==
// @name _Activate double-click on select, submits form
// @include http://YOUR_SERVER.COM/YOUR_PATH/*
// @require http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js
// @grant GM_addStyle
// ==/UserScript==
/*- The @grant directive is needed to work around a design change introduced
in GM 1.0. It restores the sandbox.
*/

$("select[name=z_pos_id] option").bind ("mousedown click", handleOptionClicks);

function handleOptionClicks (zEvent) {
_self = handleOptionClicks;
_self.optionWasSelected = _self.optionWasSelected || false;

if (zEvent.type == "mousedown") {
_self.optionWasSelected = zEvent.target.selected;
}
else {//zEvent.type == "click"
if (zEvent.target.selected && _self.optionWasSelected) {
//-- Double-click, so submit form:
$(this).parents ("form").submit ();
}
}
}
<小时/><小时/><小时/>

更新:这是一个也适用于 Chrome 的版本(需要使用脚本注入(inject))。
这假设目标页面还没有 jQuery:

// ==UserScript==
// @name _Activate double-click on select, submits form
// @include http://YOUR_SERVER.COM/YOUR_PATH/*
// @grant none
// ==/UserScript==

function GM_main ($) {
$("select[name=z_pos_id] option").bind ("mousedown click", handleOptionClicks);

function handleOptionClicks (zEvent) {
_self = handleOptionClicks;
_self.optionWasSelected = _self.optionWasSelected || false;

if (zEvent.type == "mousedown") {
_self.optionWasSelected = zEvent.target.selected;
}
else {//zEvent.type == "click"
if (zEvent.target.selected && _self.optionWasSelected) {
//-- Double-click, so submit form:
$(this).parents ("form").submit ();
}
}
}
}

add_jQuery (GM_main, "1.7.2");

function add_jQuery (callbackFn, jqVersion) {
jqVersion = jqVersion || "1.7.2";
var D = document;
var targ = D.getElementsByTagName ('head')[0] || D.body || D.documentElement;
var scriptNode = D.createElement ('script');
scriptNode.src = 'http://ajax.googleapis.com/ajax/libs/jquery/'
+ jqVersion
+ '/jquery.min.js'
;
scriptNode.addEventListener ("load", function () {
var scriptNode = D.createElement ("script");
scriptNode.textContent =
'var gm_jQuery = jQuery.noConflict (true);\n'
+ '(' + callbackFn.toString () + ')(gm_jQuery);'
;
targ.appendChild (scriptNode);
}, false);
targ.appendChild (scriptNode);
}

关于javascript - 如何通过双击下拉列表提交值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12747088/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com