总结:不要使用通常会触发回发的 asp.net 按钮,而是使用 html 制作一个。让 html 按钮运行一个 javascript 函数,该函数首先检查正则表达式验证,然后(如果有效)运行回发函数。
首先,我将删除用于触发服务器端代码的 asp.net 按钮,并将其替换为客户端按钮。如果您需要帮助创建此按钮,您可以按照我的另一个答案中的步骤操作。这是链接:
https://stackoverflow.com/questions/14062993/input-type-image-onclick-will-trigger-its-event-but-not-act-well-on-funct/14063911#14063911-Stack Overflow
其次,javascript函数应该首先使用正则表达式函数验证数据。使用这样的东西:
function validateCombobox(myComboboxValue) {
if(myComboboxValue.match(regularExpressionString)===null){
return false
} else {
return true
};
};
***注意:正则表达式对我来说是一个薄弱环节,所以你可能需要稍微修改一下这个脚本。
第三,如果使用上面的脚本验证了输入,则使用javascript调用回发。为此,请按以下步骤操作:
- 在 asp 页面上创建一个。这是必要的
因为没有它,站点将不会为
所需的按钮点击事件。
-
将链接按钮的 CSS 显示属性设置为“无”。请注意
链接按钮的“可见”属性可以设置为真(这是因为
asp.net 甚至不呈现带有 false 的控件的代码
可见属性)。为了说明,如果您的链接按钮的 cssClass
名称是 myButton,将其添加到您的 css 文件中:
.myButton
{
display: none;
}
-
现在按钮已创建并正确隐藏,您可以添加
回发函数到您的 javascript 函数。回发功能
有两个参数,第一个是客户端ID
我们创建的链接按钮控件。 注意客户端
asp.net 控件的 ID 与您分配给它的 ID 不同
在开发过程中。因此,我们使用
获取控件的客户端 ID。如果您的链接按钮 ID 是
“myLinkButton”,以下应该是您的回发功能:
__doPostBack('<%=myLinkButton.clientid %>','')
请注意,有两个下划线字符
这个函数的开头。
下面是正则表达式验证函数和新按钮应调用的 javascript 函数的示例:
function validateCombobox(myComboboxValue) {
if(myComboboxValue.match(regularExpressionString)===null){
return false
} else {
return true
};
};
function comboBoxButton_click(){
var myComboboxValue = $('#<%=myComboBox.clientid %>').val();
if(validateCombobox(myComboboxValue)==true){
__doPostBack('<%=myLinkButton.clientid %>','');
};
};
目前我有很多分心的事情,而且有点杂乱无章,所以如果这些说明有点混乱,请原谅我。如果您需要更多帮助,请随时发表评论,我会尽快回来查看。