【发布时间】:2019-08-09 21:44:32
【问题描述】:
我在 Asp.Net 网络表单中有一些页面,带有一些更新面板(带有UpdateMode="Conditional"),其中有一个 asp:LinkButton,里面有一个像这样的字体图标
<asp:LinkButton ID="btn" runat="server" CssClass="btn btn-success btn-responsive">
<span aria-hidden="true" class="fa fa-user-circle"></span> Foo
</asp:LinkButton>
当我精确点击图标时,页面会按照我的预期进行完整回发和非部分回发
搜索我知道问题可能是事件传播,所以我创建了一个这样的脚本:
$('.fa').click(function (event) {
event.stopPropagation();
if (!(this.parentNode === null)) {
this.parentNode.click();
}
});
这适用于带有 runat="server" 标记的 html 按钮,但不适用于 asp:linkbutton,我还有数千个链接按钮,我无法全部覆盖它们。 有什么建议吗?
最好的问候
更新:
这是页面:
<%@ Page Title="" Language="VB" MasterPageFile="~/MasterPage.master" AutoEventWireup="false" CodeFile="Iscr.aspx.vb" Inherits="Iscr" %>
<asp:ScriptManager ID="ScriptManager1" runat="server"></asp:ScriptManager>
<asp:UpdatePanel runat="server" ID="UpdatePanelIscr" UpdateMode="Conditional" >
<ContentTemplate>
<script type="text/javascript">
var prm = Sys.WebForms.PageRequestManager.getInstance();
prm.add_endRequest(function () {
load();
loadScript();
});
$(document).ready(function () {
loadScript();
});
function loadScript() {
}
</script>
...form....
<div class="floatingButtonBar">
<asp:LinkButton ID="btn" runat="server" CssClass="btn btn-success btn-responsive">
<span aria-hidden="true" class="fa fa-user-circle"></span> Foo
</asp:LinkButton>
</div>
</ContentTemplate>
</asp:UpdatePanel>
【问题讨论】:
-
您不需要处理事件传播。使用
return false()为LinkButton 添加OnClientClick。 -
@Sagar 这将不起作用,因为在链接按钮上带有
OnClientClick="return false;"的任何情况下它都不会启动服务器事件 -
能否请您出示脚本管理器的代码?
-
@Sagar 我编辑了帖子
标签: asp.net webforms font-awesome updatepanel