Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to run Jquery on click of an ActionLink

How do I run jquery when an MVC ActionLink is clicked? I have an action that takes some time. I want to show a 'processing' image until it returns. Is there a better way to do this?

like image 673
Bill Martin Avatar asked Feb 22 '23 21:02

Bill Martin


2 Answers

Give the actionlink a class:

@Html.ActionLink("","", new { @class:"delete" })

Then you can hook up your jQuery to the class name in a js file:

$(document).ready(function() {
  $('.delete').click(function() {
    ///Code
  });
});

You can also work with id.

like image 92
Frederiek Avatar answered Mar 03 '23 22:03

Frederiek


You can also use @Ajax.ActionLink without need of jQuery script. For example you can show a div when loading a page.

<div>
@Ajax.ActionLink("Link name", "Action", "Controller", new AjaxOptions { LoadingElementId = "loadingId", UpdateTargetId = "MyDataTable" })
</div>

<div id="loadingId" style="display:none; color:Red; font-weight: bold">
<p>Please wait...</p>
</div>

<div id = "MyData" class="tablediv">
    <table id = "MyDataTable" class="Grid">
        <tbody id="chartdata">
        </tbody>
    </table>
</div>
like image 31
Massimo Zerbini Avatar answered Mar 03 '23 23:03

Massimo Zerbini