使用jquery调用linkbutton单击

时间:2017-09-08 11:45:24

标签: c# jquery asp.net

我有一个文本框,我想要一个函数被调用onkeyup,因此我有一个隐藏按钮,试图重定向到另一个c#函数。问题是jquery进入函数内部,但后来没有进入服务器端事件。

这是我的两个元素的HTML:

                    <div class="row" style="margin-top: 5px;">
                        <div class="col-sm-12">
                            <div class="input-group input-group-sm">
                                <span class="input-group-addon">Име:</span>
                                <asp:TextBox ID="tbCliName" ClientIDMode="Static" runat="server" onkeyup="runQuery(this)" CssClass="form-control"></asp:TextBox>
                                <asp:LinkButton ID="hiddenButton" class="btn btn-default" Style="opacity: 0;" ClientIDMode="Static" OnClick="hiddenButton_Click" runat="server"></asp:LinkButton>
                                <span class="input-group-addon">Егн/Булстат:</span>
                                <asp:TextBox ID="tbEgnBStat" ClientIDMode="Static" runat="server" CssClass="form-control"></asp:TextBox>
                            </div>
                        </div>
                    </div>

这是我的jquery功能:

function runQuery(e) {
    $('#hiddenButton').click();
}

点击按钮的C#:

protected void hiddenButton_Click(object sender, EventArgs e)
{
    AutoComplete_Press(tbCliName.Text);
}

使用Ajax编辑:

function runQuery(e){ var search = $(e).val();

function runQuery(e) {
    var search = $(e).val();
    var params = {

        url: 'addEditProduct.ascx/AutoComplete_Press',
        method: 'post',
        contentType: 'aapplication/json',
        data: '{searchClause:' + search + '}',
        dataType: 'json',
        success: function (data) {
            alert(1);
        },
        error: function (data) {
            alert(2);
        }
    };

    $.ajax(params);
}



   [WebMethod]
    public static void AutoComplete_Press(string searchClause)
    {
        int searchType = 0; //ЕГН
        int csKind = 0;

        Regex regex = new Regex("^[0-9]+$");
        if (!regex.IsMatch(searchClause))
            searchType = 1;

        //if (rbLP.Checked)
        //    csKind = 1;

        string clients = laboratory.getClients2(searchType, searchClause, 1);
    }

3 个答案:

答案 0 :(得分:1)

尝试使用webmethod。在服务器端

[WebMethod]
public static void BindData()
{
  AutoComplete_Press(tbCliName.Text);
}

在客户端

 $("#hiddenButton").click(function() {
        $.ajax({
            type: "POST",
            url: "index.aspx/BindData",
            contentType: "application/json; charset=utf-8",
            data: JSON.stringify({/*pass values here*/}),
            dataType: "json",      
        });
    });

请参阅以下链接 https://www.aspsnippets.com/Articles/Calling-server-side-methods-using-JavaScript-and-JQuery-in-ASP.Net.aspx

答案 1 :(得分:1)

它无效的原因是您使用的asp:LinkButton呈现为a元素,href属性设置为javascript:__doPostBack()

如果您将asp:LinkButton替换为asp:Button,则$('#hiddenButton').click();将开始工作。

只需更改此行代码

即可
<asp:LinkButton ID="hiddenButton" class="btn btn-default" Style="opacity: 0;" ClientIDMode="Static" OnClick="hiddenButton_Click" runat="server"></asp:LinkButton>

到这个

<asp:Button ID="hiddenButton" class="btn btn-default" Style="opacity: 0;" ClientIDMode="Static" OnClick="hiddenButton_Click" runat="server"></asp:Button>

答案 2 :(得分:1)

您可以调用此类函数,但不能调用事件 创建Web方法并尝试Jquery Ajax

var params = {
                url: 'Index.aspx/YourWebmethod',
                type: "POST",
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                traditional: true,
                data: JSON.stringify(data to be send ), 
                success: function (result) {
                    alert('Success');
                },
                error: function (result) { alert('Warning! It failed.'); }
            };
            $.ajax(params);