Вызовите код позади функции из JavaScript (не AJAX!)
У меня есть функция на моей стороне сервера.
protected void SelectParticipant(string CompanyId, string EmployeeNumber)
{
//I do some stuff here.
}
Я хочу вызвать эту функцию из JavaScript на стороне клиента. Я пытался найти его, но все предложения, которые я нашел, были для вызова метода страницы через AJAX. Я не хочу этого, я хочу вызвать обратную передачу.
function MyJSFunction(companyid, employeenumber)
{
//cause postback and pass the companyid and employee number
//this is where I need help!
}
Как я могу вызвать обратную передачу и запустить функцию на стороне сервера из моего JavaScript?
3 ответа
Вот как я это сделал...
<script type="text/javascript">
function AddParticipant(companyid, employeenumber)
{
$("#AddParticipantPanel").dialog("close");
var myargs = {CompanyId: companyid, EmployeeNumber: employeenumber};
var myargs_json = JSON.stringify(myargs);
__doPostBack('<%= SelectParticipantBtn.UniqueID %>', myargs_json);
}
</script>
<asp:Button runat="server" ID="SelectParticipantBtn" ClientIDMode="Static" OnClick="SelectParticipantBtn_Click" style="display:none;" />
И на стороне сервера...
/* this is an inner class */
public class SelectParticipantEventArgs
{
public string CompanyId {get; set;}
public string EmployeeNumber {get; set;}
}
protected void SelectParticipantBtn_Click(object sender, EventArgs e)
{
string args = Request.Form["__EVENTARGUMENT"];
var myargs = JsonConvert.DeserializeObject<SelectParticipantEventArgs>(args);
string emp_no = myargs.EmployeeNumber;
string company_id = myargs.CompanyId;
//do stuff with my arguments
}
Вместо использования HiddenFields я использовал скрытую кнопку. Эта модель работает лучше, потому что я могу перейти непосредственно к обработчику событий кнопки вместо того, чтобы добавлять код в функцию Page_Load.
Вы можете решить свою проблему, используя два HiddenField
,
- Установите два HiddenField, используя js/jquery(как вы предпочитаете)
- Принудительно отправить форму в функции js (
form1.submit()
) - В formLoad проверьте, являются ли поля HiddenFields пустыми. Если нет, запустите ваш метод, а затем очистите HiddenFields
Вы можете использовать функцию __doPostBack для публикации на сервере. просто убедитесь, что вы добавили серверный элемент управления на страницу, чтобы функция была вставлена. Вот небольшой пример, который вы можете настроить для своих нужд:
ASPX:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="Try1.WebForm1" EnableEventValidation="false"%>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script src="Scripts/jquery-1.10.2.min.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$('#lblInvoke').hover(
function () {
__doPostBack('<%= LinkButton1.ClientID %>', 'value1,value2');
}
);
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<label id="lblInvoke">Hover This!</label>
<br />
<asp:LinkButton ID="LinkButton1" runat="server" OnClick="LinkButton1_Click" Style="display:none;">LinkButton</asp:LinkButton>
<asp:Label ID="Label1" runat="server" Text=""></asp:Label>
</div>
</form>
</body>
</html>
код позади:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Try1
{
public partial class WebForm1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void LinkButton1_Click(object sender, EventArgs e)
{
string passedArgument = Request.Params.Get("__EVENTARGUMENT");
string[] paramsArray = passedArgument.Split(',');
Label1.Text = string.Format("Returned from server. params: {0},{1}", paramsArray[0], paramsArray[1]);
}
}
}
Убедитесь, что вы добавили атрибут EnableEventValidation="false" на страницу.