DEV Community

Adrian Matei for CodepediaOrg

Posted on • Originally published at codepedia.org

1 1

How to verify link clicked in Angular html template

Being on a constant lookout for optimisation when managing my bookmarks on www.bookmarks.dev, I had this idea lately to add a bookmark to my history not only when I click the title of the bookmark (main URL), but also when I click hyperlinks in the description of the bookmark - sometimes I tend to bookmark the "parent" url and add "child" or related bookmarks in the description (an example would be bookmarking the same "resource" which is deployed on different environments like dev, test and prod):

Demo showing this in action

This plays really well now with the recently introduced hot keys to access the history and pinned bookmarks

Well, let's see how this looks like in code:

The HTML template

    <app-bookmark-text
      [bookmark]="bookmark"
      [queryText]="queryText"
      (click)="onClickInDescription($event, bookmark)"
      (auxclick)="onMiddleClickInDescription($event, bookmark)"
      (contextmenu)="onRightClickInDescription($event, bookmark)">
    </app-bookmark-text>
Enter fullscreen mode Exit fullscreen mode

In the template we listen to the following events the Angular API provides:

  • onClick - fires when the user clicks the left mouse button on the object
  • onauxclick - to cover the middle button click of the mouse I use the auxclick1 event, which is fired at an Element when a non-primary pointing device button (any mouse button other than the primary—usually leftmost—button) has been pressed and released both within the same element.fires when the user clicks the left mouse button on the object
  • oncontextmenu - fires when the user clicks the right mouse button in the client area, opening the context menu.

The Angular component

Let's see how this is implemented in the component:

  onClickInDescription($event: any, bookmark: Bookmark) {
    if (this.isHtmlAnchorElement($event)) {
      $event.target.setAttribute('target', '_blank');
      this.addToHistoryIfLoggedIn(bookmark);
    }
  }

  onRightClickInDescription($event: any, bookmark: Bookmark) {
    if (this.isHtmlAnchorElement($event)) {
      this.addToHistoryIfLoggedIn(bookmark);
    }
  }

  onMiddleClickInDescription($event: any, bookmark: Bookmark) {
    if (this.isHtmlAnchorElement($event)) {
      this.addToHistoryIfLoggedIn(bookmark);
    }
  }

  private isHtmlAnchorElement($event: any) {
    return $event.target.matches('a');
  }
Enter fullscreen mode Exit fullscreen mode

The pattern is the same: verify that the object onto which the event was dispatched is an HTML Anchor - isHtmlAnchorElement(). If that's the case it will be added to my bookmarks history.

To achieve that, we use the target2 property of the Event interface with the matches(selector)3 method. In this particular case we use a as selectorString. For other html elements use a corresponding selector.

Note:

  • on left click we force opening the URL in a new tab by setting the target attribute to _blank - $event.target.setAttribute('target', '_blank');
  • on right click I haven't found a way yet to verify if the user clicked "Open Link in New Tab" or "Open Link in New Window" - suggestions are more than welcomed; but for the time being I think it is enough, what else would you do a right click on a link for?

Conclusion

This is definitely a piece of code I will bookmark for later.

References


  1. https://developer.mozilla.org/en-US/docs/Web/API/Element/auxclick_event 

  2. https://developer.mozilla.org/en-US/docs/Web/API/Event/target 

  3. https://developer.mozilla.org/en-US/docs/Web/API/Element/matches 

SurveyJS custom survey software

Simplify data collection in your JS app with a fully integrated form management platform. Includes support for custom question types, skip logic, integrated CCS editor, PDF export, real-time analytics & more. Integrates with any backend system, giving you full control over your data and no user limits.

Learn more

Top comments (0)

SurveyJS custom survey software

JavaScript Form Builder UI Component

Generate dynamic JSON-driven forms directly in your JavaScript app (Angular, React, Vue.js, jQuery) with a fully customizable drag-and-drop form builder. Easily integrate with any backend system and retain full ownership over your data, with no user or form submission limits.

Learn more

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay