gallagher gallagher - 2 years ago 193
jQuery Question

Convert jquery click function into angularJS directive

For a 'skip to content' accessibility link, this jquery in a controller works well:

$scope.skipLink = $( document ).ready(function() {
var skipTo="#"+this.href.split('#')[1];
$(skipTo).attr('tabindex', -1).on('blur focusout', function () {

Where the HTML is

<a href="#content" class="skip sr-only sr-only-focusable">Skip to content</a>

Is there a way to rewrite this into a directive without using jquery?

Answer Source

In my opinion, I don't think this should be done without jQuery. In order to make it more angular-friendly however, see THIS DEMO.

The idea is to leverage the click handler directives from angular and let jQuery do its work inside of your controller.

AngularJS Controller

  $scope.skipToContent = function () {
    $("#content").attr('tabindex', -1);
  $scope.removeTabIndex = function () {


<a href="#content" 
   class="skip sr-only sr-only-focusable">Skip to content</a>
<input id="content" 
       style="display: block; margin-top:100vh;"/>
Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download