I didn't plan on writing too much about web development here, but for the past months I've been learning modern web frameworks/techonologies and I've found something worthy writing about regarding Angular.
In Angular, as in other well designed framework you are expected to separate concerns as much as possible. For instance, Component
s should be as reusable as possible. One feature for such reusability is self-containment. That is, while sometimes you need their host component to interact with them beyond their APIs (Input
s, Output
s, etc.), you need to move in a slightly lower layer for things like adding/removing CSS classes. But you can take measures so everything is under control.
Nonetheless, you can see yourself in trouble with the markup. Due to the rigidity of HTML, certain elements must be direct children of their 'semantic ancestors' if you don't want the browser to make a mess out of your markup. For instance, a <tr>
must be a direct child of a <table>
, or at least of a <thead>
, <tbody>
or <tfoot>
—among a few others that don't alleviate the issue—. The same holds for lists; for instance an <ul>
must contain <li>
s.
Let's look at the problem with a concrete example.