- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我在 Controller 下声明指令时,例如
<div ng-controller="MyController">
<my-directive></my-directive>
</div>
该指令默认继承该 Controller 的范围。这意味着如果 Controller 定义了
$scope.Heaven = "Free Beer"
然后我可以通过以下方式访问指令模板中的内容
{{ Heaven }}
当在另一个指令中声明一个指令时,为什么子指令不像放置在 Controller 中那样继承作用域?
<my-parent-directive>
<my-child-directive>
</my-child-directive>
</my-parent-directive>
简而言之,如果我为 my-parent-directive 声明一个 Controller 函数并在其中写入:
$scope.Heaven = "Free Beer"
默认情况下,我的子指令无权访问此指令。这是为什么?(这假设父级中为“scope: true”,子级中没有范围声明,并且子级通过“require: 'my-parent-directive' 需要父级)
Directive wrapped in controller
Directive wrapped in directive
给出答案后问题被修改 - 以下是为了保留引用
Directive wrapped in directive old
最佳答案
我正在 codepen 上查看“Directive wrapped in directive old ”。我认为这是您想要解决的问题,但我不确定,因为您的代码笔与您问题中的示例不同(这不是批评,只是澄清,以防我走错了路!)
但是,如果我是正确的(并且我指的是 codepen 上的“Directive wrapped in directive old”作为本答案的其余部分):
您已将 myWrapper 中的范围声明为继承(“scope: true
”),因此您添加到 myWrapper 中的范围的任何属性(例如“$scope.passdown = $attrs.passdown;
") 仅对 myWrapper 可见。
您可以从 myWrapper 中删除“scope: true
”,以在所有内容之间共享范围(不是一个很好的结构,但它会起作用),如果我已经正确理解你了。或者,您可以将“passdown
”属性移动到“父” Controller “$scope.abc = {passdown: ''};
”上的可变对象。然后修改 myWrapper 中的值:“$scope.abc.passdown = $attrs.passdown;
”并在插值表达式中将其作为“abc.passdown
”访问。
一些背景:
对“子” Controller /指令中的不可变类型的更改将创建属性的副本,并且这些更改将永远不会在任何其他作用域中看到。
没有作用域声明意味着共享作用域 - 共享此作用域的所有组件也可以看到在该作用域上所做的任何属性/更改(对可变对象)。往往会导致紧密耦合的组件变得非常难以维护。
“scope: true
”表示继承范围,并且对该范围所做的任何添加仅对继承范围(即“子”)可见。父级中可变属性的更改对于共享此范围的所有其他组件都是可见的。
“scope: {...}”创建一个隔离的范围,并提供一种安全的方法来向父级公开属性并让子级修改这些属性。此实现需要更多工作,但您最终会得到更易于理解、维护和共享的代码。
我希望这个答案不会太杂乱,它可以帮助您解决问题。
关于AngularJS : directive scope inheritance,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27334354/
我正在为我的项目测试 FlowJS,我遇到了 Type Aliases 的问题. 我为 API 构建了一个 Web SDK:我有一个使用此方法的 Helper 类: class Helper {
我是 Dart 的新手,仍在学习它带来的所有细微差别。我当前的任务真正困扰的一件事是从父类继承(或代理)静态方法。 void main() { EnglishCasual.greet(); } c
我正在尝试巩固 Go 提供的继承概念(也许是“组合”而不是纯粹的继承)。但是,我无法理解为什么我不能将“父”类型用作 func 参数来生成作用于该参数的通用函数。 package main impor
我在准确表述它时遇到问题,所以我在标题中留下了更笼统的描述(如果您对问题有更准确的描述,请发表评论,我会编辑标题)。 问题: AudioStream 和VideoStream 两个类派生自基类Medi
我的应用程序不仅具有“用户”,而且还具有“管理员”和“ super 管理员”。由于所有这三个共享相同的属性,因此我只想使用一个带有附加属性“role”的表,该属性可以是“user”,“admin”或“
我正在使用数据库优先方法和 DbContext。我的数据模型中有几个继承结构 (TPH)。但是 DbContext 只为基类创建一个 DbSet,而没有为子类创建一个 DbSet。我应该如何检索指定子
我正在使用数据库优先方法和 DbContext。我的数据模型中有几个继承结构 (TPH)。但是 DbContext 只为基类创建一个 DbSet,而没有为子类创建一个 DbSet。我应该如何检索指定子
我有一个生成很多子对象的应用程序,每个子对象都与一些全局应用程序对象一起工作,例如在全局应用程序注册表中注册自己,更新应用程序统计信息等。 应用程序应该如何将访问这些全局对象的能力传递给 child
我有 2 个结构,其中一个继承了由 type Common struct {...} 表示的所有结构中共有的值 type Common struct{ Id int CreatedAt
我的代码: Ext.onReady(function() { // Every property is declared inside the class Ext.define('MyCustomPa
我有一个包含多个类的应用程序,这些类继承/是第三方库类的子类。例如,来自 Qt Framework 的 QDialog。 我应该在应用程序的 UML 类图中指定继承关系吗? 是否期望(或标准)表示此类
我遇到了这个问题,因为我认为我对 Backbone 的理解不正确。 我有一个名为 Runnable 的父类(super class)和一组继承自它的子类: var Runnable = Backbon
考虑以下 HTML: foo bar 和 CSS: a { text-decoration:none; border-bottom-width: 0px; border-bot
我想做个模板Class BaseDialog ,但在进行最终对话时 MyDialog1 , 继承了 BaseDialog , 我收到错误,然后无法在设计模式下显示对话框。 以下是我得到的错误列表。 a
我对 android 文档中的这两个术语感到困惑!! these screenshot about what i mean 最佳答案 常量是用 static 和 final 修饰符声明的字段。继承常量
我最近遇到了一个新的警告: 继承构造函数不继承省略号 我正在尝试管道 Object{42}; // ... into an init that handles integers ...和... Obj
我正在使用 TypeScript 开发 Aurelia 应用程序。在此应用程序中,我定义了一组自定义元素,每个元素共享一组可绑定(bind)属性,这些属性被转换为 css 设置,如以下简化示例所示:
我想知道为什么人们会说: “继承类不继承构造函数”。 如果你可以使用父类的构造函数,无参构造函数无论如何都会被自动调用。 例子: #include using namespace std; clas
我刚刚开始探索 Kotlin 语言。我正在为继承、var&val 和副作用而苦苦挣扎。 如果我用 val x 声明一个特征 A 并在 AImpl 中覆盖 x ,则可以将其覆盖为 var(参见下面的代码
我正面临一个编码/解码问题,涉及使用 MOXy 的 JAXB 实现和外部元数据绑定(bind)文件的继承和多态性。 我无法控制 XML 文件或模型类。 模型内部有多个类继承其他 DTO 类。 这是我正
我是一名优秀的程序员,十分优秀!