提问人:amelia zaripova 提问时间:6/22/2022 最后编辑:robniamelia zaripova 更新时间:9/15/2023 访问量:618
如何使回车键根据哪个字段为空单击不同的按钮?
how to make enter key click on different buttons depending on which field is empty?
问:
我有一个使用 vb 编码 asp.net Web 表单,它有多个文本框和按钮。如果一个文本框为空,我希望在按下回车键时单击一个按钮,而如果另一个文本框为空,我希望在按下回车键时单击另一个按钮。我知道我可以更改表单部分中的默认按钮,但我不知道如何根据哪个文本框是空的来更改默认按钮?我想我必须在javascript中做到这一点,我对此知之甚少,因此任何帮助将不胜感激。
我可以做这样的事情来更改默认按钮吗?
If txtMembranePressure.Text = "" Then
Dim sb As New System.Text.StringBuilder()
sb.Append("<form id='form1' runat='server'" + "defaultbutton='btnMembranePressure'")
Else
Dim sb As New System.Text.StringBuilder()
sb.Append("<form id='form1' runat='server'" + "defaultbutton='btnDiamondPressure'")
End If
我可以像这样将默认按钮直接放在表单上吗?
答:
有 3 个步骤要做。
- 您需要知道文本框何时更改。为此,您可以使用 .
TexboxChanged Event
- 您需要知道,如果 .
Textbox is empty
- 您需要知道如何更改 .
default button
每个 Textbox 都需要一个 TextboxChanged 事件。在每种情况下,您都应该检查文本框是否为空。如果它为空,则应将其设置为默认值。
在伪代码中:
if Textbox.Text = "" then
set Textbox to default
有关文本框更改 EVent 的详细信息,请在搜索引擎(例如 duckduckgo.com)中搜索“文本框更改事件”:
https://meeraacademy.com/textbox-autopostback-and-textchanged-event-asp-net/
要更改默认按钮,请考虑以下 Stackoverflow 的答案:如何在 ASP.Net 中为 TextBox 设置默认按钮?
评论
拥有一次单击例程不是更好吗 - 所有按钮都可以自由地指向该单击例程 - 但是在该单击例程中,您可以自由检查给定文本框的值,然后运行所需的代码。这似乎比尝试更改应该单击的实际按钮要复杂得多。因此,让所有按钮都运行相同的例程,但该例程可以简单地检查哪些文本框中有值。
然后,根据哪些文本框具有(或没有)值,您可以根据此信息简单地运行或调用所需的代码。
请记住,在大多数情况下,按回车键将触发该文本框后面标记中控件后面的按钮。 编辑:更正:页面上的第一个按钮将触发。
但是,您可以通过在按钮标记中设置 usesubmitBehaviour=False 来关闭此行为
<asp:TextBox ID="txtSearchOC" runat="server"></asp:TextBox>
<asp:Button ID="Button1" runat="server" Text="Button"
UseSubmitBehavior="False" />
事实上,如果你在窗体上放一个文本框,那么假设一个有 10 行的网格视图,而网格视图的每一行都有带有点击事件的按钮?点击上面的回车键实际上会触发网格视图的第一行按钮单击!!
因此,通常通过正确放置按钮,比如说一个搜索文本框,以及一个按钮之后点击“搜索数据”,那么实际上,如果他们按回车键,该文本框后面的按钮无论如何都会触发。(如前所述,标记上的第一个按钮会触发 - 不是任何按钮,或者实际上不是文本框后面的按钮)。
因此,在某些情况下,文本框的正确顺序以及后面的按钮可以在这里得到很好的利用。但是,它经常会让你大吃一惊。你放入一个文本框,一个表单后面有 10 个按钮,其中一个按钮会在你按回车键时触发 - 这通常更难防止这种情况发生。
因此,请记住上述内容。但是,假设您希望代码基于文本框中的值(或缺少值)运行,那么我将有一个按钮单击全部使用的例程,然后隐藏的代码可以检查文本框值,并采取所需的操作过程并根据此信息运行所需的代码。
评论
我在下面为您提供了足够的细节和示例代码,以便您自己重新设计它,即使我不太理解您的要求。我同意上面的评论,这可能不是最好的方法。最好在服务器端检查是否填充了文本框,然后在代码中遵循不同的路径。
JQuery 允许您按类名查找元素(在 .NET 中为 CssClass=“”,在普通 HTML 元素上为 class=“”)
$(".ClassName“) 使 JQuery 在页面上查找具有该类名的所有元素。 $(“#Id”) 使 JQuery 在页面上查找具有该 ID 的所有元素。
data-whatYouWantToStore 是一种针对元素存储数据的便捷方式,然后您可以使用 Javascript / JQuery 读取这些数据。只需将其全部保持小写即可避免打扰它。
$(element).data(“data-bit后面的名称”) 将得到值。
要使其运行,唯一需要更改的位是文本框:
data-targetbuttonemptyclass="js-button-1" data-targetbuttonnotemptyclass="js-button-2"
如果属性中的文本框为空,则设置在按下 Enter 时希望单击的按钮的类,如果属性中存在文本,则设置要单击的按钮。如果文本框上必须设置了类,才能让它们由“空/非空”的 JavasScript 处理。data-targetbuttonemptyclass
data-targetbuttonnotemptyclass
js-click-if-not-empty
<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="Buttons.aspx.vb" Inherits="Scrap.Buttons" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<!--Add reference to Jquery CDN -->
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<!--Your Javascript -->
<script type="text/javascript">
$(document).ready(function () {
// find all the buttons we want to set this behaviour on
$(".js-click-if-not-empty").each(function () {
// add a keypress event hander to each button
$(this).on("keypress", function () {
// get the key that was pressed
var keycode = (event.keyCode ? event.keyCode : event.which);
// is it the ENTER key?
if (keycode === 13) {
// prevent anything else that was going to happen because enter was pressed.
event.preventDefault();
// is the textbox empty?
if ($(this).val() === "") {
// yes - get the css class of the button to click when the textbox is empty
var button = $("." + $(this).data("targetbuttonemptyclass"))[0];
// just for debugging to show which button is about to be clicked
alert("going to click empty button: " + button.id);
// click the button
button.click();
} else {
// no - get the css class of the button to click when the textbox is not empty
var button = $("." + $(this).data("targetbuttonnotemptyclass"))[0];
// just for debugging to show which button is about to be clicked
alert("going to click not empty button: " + button.id);
// click the button
button.click();
}
};
});
});
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:TextBox ID="tb_TextBox1" runat="server" CssClass="js-click-if-not-empty" data-targetbuttonemptyclass="js-button-1" data-targetbuttonnotemptyclass="js-button-2"></asp:TextBox>
<asp:TextBox ID="tb_TextBox2" runat="server" CssClass="js-click-if-not-empty" data-targetbuttonemptyclass="js-button-1" data-targetbuttonnotemptyclass="js-button-2"></asp:TextBox>
<asp:TextBox ID="tb_TextBox3" runat="server" CssClass="js-click-if-not-empty" data-targetbuttonemptyclass="js-button-1" data-targetbuttonnotemptyclass="js-button-2"></asp:TextBox>
<asp:Button ID="btn_ClickIfEmpty" runat="server" CssClass="js-button-1" Text="Click If Empty" />
<asp:Button ID="btn_ClickIfNotEmpty" runat="server" CssClass="js-button-2" Text="Click If Not Empty" />
</div>
</form>
</body>
</html>
评论
在要指向单个按钮的所有控件周围添加asp:panel,在面板属性“DefaultButton”上提供您希望它使用的面板的ID! 2分钟工作!
评论