With this post I would show how to call server side method from client side. Here we will use jQuery to utilize the Ajax Capabilities which will help us to get/post data to/from server Asynchronously. There are many methods available to perform an async callback to the server. Here I will show a simple example as in how to call a code behind Webmethod.
For simplicity I would be calling the code behind method on a Button Click. Here is the code:
Aspx markup:
1: <asp:Button ID="Button1" runat="server" Text="Click" />
2: <br /><br />
3: <div id="myDiv"></div>
1: <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js" type="text/javascript"></script>
2: <script type ="text/javascript">
3: $(document).ready(function () {
4: $('#<%=Button1.ClientID %>').click(function () {
5: $.ajax({
6: type: "POST",
7: url: "WebForm1.aspx/ServerSideMethod",
8: data: "{}",
9: contentType: "application/json; charset=utf-8",
10: dataType: "json",
11: async: true,
12: cache: false,
13: success: function (msg) {
14: $('#myDiv').text(msg.d);
15: }
16: })
17: return false;
18: });
19: });
20: </script>
1: [WebMethod]
2: public static string ServerSideMethod()
3: {
4: return "Message from server.";
5: }
If you want to send parameters to your code behind method, you would change the line 8 in the above jQuery code as:
1: data: "{'param1': 1}"
2: data: "{'pageNumber' :'1','pageSize' : '10'}",
The method would change as:
1: [WebMethod]
2: public static string ServerSideMethod(string param1)
3: {
4: return "Message from server with parameter:"+param1;
5: }
Message from server with parameter:1
You could also call any webmethod method in your webservice by changing the url in the jQuery as:
1: url: "WebService1.asmx/ServerSideMethod"
Recently I have seen a lot of questions from members in the asp.net forums asking about how to call Javascript confirm on button click and then based on user selection ie Yes/No process code behind logic.
Here is another example of how to do so:
1: function MyConfirmMethod() {
2: if (confirm('Are your sure?')) {
3: $.ajax({
4: type: "POST",
5: url: "WebForm1.aspx/ServerSideMethod",
6: data: "{}",
7: contentType: "application/json; charset=utf-8",
8: dataType: "json",
9: success: function (msg) {
10: $('#myDiv').text(msg.d);
11: }
12: });
13: return false;
14: }
15: else {
16: return false;
17: }
18: }
1: protected void Page_Load(object sender, EventArgs e)
2: {
3: Button1.Attributes.Add("onclick", "return MyConfirmMethod();");
4: }
5: [WebMethod]
6: public static string ServerSideMethod()
7: {
8: return "Message from server!";
9: }
No comments:
Post a Comment