- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们一直在避免将 Angularjs 指令限制为类。主要是因为我们发现了一些建议不要这样做的来源(包括 John Papas opinionated styleguide )。同时,我们一直避免将其限制为元素,因为这会与 W3C 标准相冲突。 (我们就是这样的纯粹主义者)。
所以,我们一直使用的是对属性的限制(不,我们不会讨论注释方法)。在大多数情况下工作正常,但在部署具体对象时似乎太松散。例如。侧边栏。这以及 replace: true
选项将是 deprecated ,让我想知道为什么不使用限制来上课。看起来很有道理:
<nav class="maarten-sidebar">
<!-- sidebar directive content -->
</nav>
比较:
<div data-maarten-sidebar>
<!-- sidebar directive content -->
<nav class="sidebar"></nav>
</div>
它也能很好地与我们的 CSS 文件配合使用。通过一些研究,我们发现有些人反对这样做。但不这样做的主要原因还不是很清楚。所以我的问题实际上是:使用 restrict: 'C'
最佳答案
有几个原因 restrict: 'E'
通常被认为是带有模板的指令的最佳实践(在 Angular 2 中称为 'components',并受到 Angular 1 中新的 component 指令的鼓励)。原因实际上只是关于可读性和一致性,但我认为它们仍然令人信服。
主要原因正是因为它与W3C标准相冲突。根据标准,elements may not contain separate words delimited by a dash 。 AngularJS encourages developers在指令名称中的某处使用破折号。因此,当您看到一个带有破折号的元素时,您立即知道它是一个 Angular 指令,而不是一个标准的 HTML 元素。因此,使用 restrict: 'E'
最终变得更具可读性和表现力。
现在,对于没有模板的指令(Angular 2 中的普通旧 'directives'), restrict: 'A'
一般是首选。大多数 HTML 属性不包含破折号,尽管有 nothing in the W3C standard这说明他们不能。主要原因似乎是它们赋予元素一种行为,而不是像许多 HTML 属性那样简单地应用视觉样式(例如 onclick
)。此外,如果指令接受输入,您可能会通过自定义属性绑定(bind)输入,如下所示:<nav expandable-nav expanded="false"></nav>
。另一方面,这似乎很令人困惑: <nav class="expandable-nav" expanded="false"></nav>
.
最后,也许顺应潮流的主要原因是它们在 Angular 2 中得到了强制执行。不可避免的是,Angular 2 将成为下一个大事件,而 Angular 1 一直在朝着更加 Angular-2 的方向发展。无论如何方向(例如使用 component 指令)。做好准备...
关于javascript - 为什么将 AngularJS 指令限制为类是不好的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35524788/
非常简单的应用程序 - 您可以复制 - 粘贴 - 运行。主要只是“创建”应用程序。 - 这不是问题(可能) #include #include #include #include typede
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 6 年前。 Improve t
Haskell 有一个名为 seq 的神奇函数,它接受任何类型的参数并将其简化为弱头范式 (WHNF)。 我读过一些资料[但我现在不记得他们是谁了...],它们声称“多态 seq 很糟糕”。他们在哪些
我正在编写一个脚本,该脚本应该在一堆服务器周围运行并从中选择一堆数据,包括本地服务器。选择我需要的数据所需的 SQL 非常复杂,所以我正在编写一种临时 View ,并使用 OPENQUERY 语句来获
考虑以下代码: case class Vector3(var x: Float, var y: Float, var z: Float) { def add(v: Vector3): Unit =
我正在读这个SO post关于守护线程,答案底部的引述是: But joining a demonized thread opens most likely a whole can of troubl
在阅读有关 Google webtool 工具包的内容时,看到一条声明说“同步 RPC 不好”。他们有什么理由吗?我能想到的一个很好的理由是,对最终用户的响应可能会受到远程服务器延迟或网络问题的影
我有以下 HTML: A Simple Sample Web Page By Sheldon Brown Demonstrating a few HTML feat
我正在做一项简单的任务,但我陷入困境...... output 我需要使第一行与其他所有内容保持一致,但无论我做什么,它都不想接受空格。那么,我应该纠正什么以及为什么?谢谢 public static
我在系统中有一个类,其目的列为“这可以是从午夜算起的秒数。或者带有日期的时间。”我试图解释这有多糟糕,但我无法理解我的观点。有没有人对如何解决这个问题有任何想法。 http://code-slim-j
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: When are C++ macros beneficial? Why is #define bad and
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
始终建议通过将所有代码放在 JS 文件中来避免内联 Javascript 代码,该文件包含在所有页面中。我想知道,这是否不会导致繁重的页面出现性能问题。 例如,假设我们有几十个这样的函数 functi
我主要在 AngularJS 中进行开发,最近我正在研究 Vue.js 并阅读它的指南,在它提到的一页上: By default, all props form a one-way-down bind
我正在构建一个本地化目录,但遇到了设计难题。现在,目录存储一个 Dictionary存储翻译,其中 IString可以是两种类型:Singular或 Plural .这是 IString 的简化版本:
对于我的矩阵类,我做了: template class Matrix { private: std::array, Height> Elements; stat
MSDN documentation说 public class SomeObject { public void SomeOperation() { lock(this) {
建议不要在 Python 中使用 import *。 谁能分享一下原因,这样我下次就可以避免了? 最佳答案 因为它会将很多东西放入您的命名空间(可能会影响之前导入的一些其他对象,而您不会知道它)。 因
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
G'day, 这与my question on star developers有关并到 this question regarding telling someone that they're wri
我是一名优秀的程序员,十分优秀!