AngularJS Directive Restrict A vs E

JavascriptHtmlAngularjs

Javascript Problem Overview


I'm working in a small team, building in AngularJS and trying to maintain some basic standards & best practices; especially given we're relatively new with Angular.

My question is with regards to Directives. More accurately, the restrict options.

Some of us are using restrict: 'E' thus having <my-directive></my-directive> in the html.

Others are using restrict: 'A' and having <div my-directive></div> in the html.

Then, of course, you can use restrict: 'EA' and use either of the above.

At the moment it's no big deal, though when this project is as big as it's going to get I would like anybody looking at it to easily understand what's going on.

Are there pros/cons to either the attribute or element way of doing things?

Are there any pitfalls we should know, if choosing say element over attribute?

Javascript Solutions


Solution 1 - Javascript

restrict is for defining the directive type, and it can be A (Attribute), C (Class), E (Element), and M (coMment) , let's assume that the name of the directive is Doc :

> Type : Usage > > A = <div Doc></div> > > C = <div class="Doc"></div> > > E = <Doc data="book_data"></Doc> > > M = <!--directive:Doc -->

Solution 2 - Javascript

According to the documentation:

> When should I use an attribute versus an element? Use an element when > you are creating a component that is in control of the template. The > common case for this is when you are creating a Domain-Specific > Language for parts of your template. Use an attribute when you are > decorating an existing element with new functionality.

Edit following comment on pitfalls for a complete answer:

Assuming you're building an app that should run on Internet Explorer <= 8, whom support has been dropped by AngularJS team from AngularJS 1.3, you have to follow the following instructions in order to make it working: https://docs.angularjs.org/guide/ie

Solution 3 - Javascript

The restrict option is typically set to:

  • 'A' - only matches attribute name
  • 'E' - only matches element name
  • 'C' - only matches class name
  • 'M' - only matches comment

Here is the documentation link.

Solution 4 - Javascript

Element is not supported in IE8 out of the box you have to do some work to make IE8 accept custom tags.

One advantage of using an attribute over an element is that you can apply multiple directives to the same DOM node. This is particularly handy for things like form controls where you can highlight, disable, or add labels etc. with additional attributes without having to wrap the element in a bunch of tags.

Solution 5 - Javascript

One of the pitfalls as I know is IE problem with custom elements. As quoted from the docs:

> 3) you do not use custom element tags such as (use the > attribute version

instead)

> 4) if you do use custom element tags, then you must take these steps to > make IE 8 and below happy

<!doctype html>
  <html xmlns:ng="http://angularjs.org" id="ng-app" ng-app="optionalModuleName">
    <head>
      <!--[if lte IE 8]>
        <script>
          document.createElement('ng-include');
          document.createElement('ng-pluralize');
          document.createElement('ng-view');
 
          // Optionally these for CSS
          document.createElement('ng:include');
          document.createElement('ng:pluralize');
          document.createElement('ng:view');
        </script>
      <![endif]-->
    </head>
    <body>
      ...
    </body>
  </html>

Solution 6 - Javascript

Pitfall:

  1. Using your own html element like <my-directive></my-directive> wont work on IE8 without workaround (https://docs.angularjs.org/guide/ie)
  2. Using your own html elements will make html validation fail.
  3. Directives with equal one parameter can done like this:

<div data-my-directive="ValueOfTheFirstParameter"></div>

Instead of this:

<my-directive my-param="ValueOfTheFirstParameter"></my-directive>

We dont use custom html elements, because if this 2 facts.

Every directive by third party framework can be written in two ways:

<my-directive></my-directive>

or

<div data-my-directive></div>

does the same.

Solution 7 - Javascript

2 problems with elements:

  1. Bad support with old browsers.
  2. SEO - Google's engine doesn't like them.

Use Attributes.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionDarren WainwrightView Question on Stackoverflow
Solution 1 - JavascriptSeif TmlView Answer on Stackoverflow
Solution 2 - JavascriptngasullView Answer on Stackoverflow
Solution 3 - Javascriptnikunj gandhiView Answer on Stackoverflow
Solution 4 - JavascriptJack AllanView Answer on Stackoverflow
Solution 5 - JavascriptKhanh TOView Answer on Stackoverflow
Solution 6 - JavascriptKonstantin KrassView Answer on Stackoverflow
Solution 7 - JavascriptAmir PopovichView Answer on Stackoverflow