- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有以下代码,也可以在http://jsfiddle.net/garukun/u69PT/上摆弄.
查看:
<div data-ng-app="testApp">
<div data-ng-controller="testCtrl">
<strong>{{pkey}}</strong>
<span data-test-directive data-parent-item="pkey"
data-parent-update="update(pkey)"></span>
</div>
</div>
JS:
var testApp = angular.module('testApp', []);
testApp.directive('testDirective', function ($timeout) {
return {
scope: {
key: '=parentItem',
parentUpdate: '&'
},
replace: true,
template: '<div><p>{{key}}</p>' +
'<button data-ng-click="lock()">Lock</button>' +
'</div>',
controller: function ($scope, $element, $attrs) {
$scope.lock = function () {
$scope.key = 'D+' + $scope.key;
console.log('DIR :', $scope.key);
// Expecting $scope.$parent.pkey to have also been
// updated before invoking the next line.
$scope.parentUpdate();
// $timeout($scope.parentUpdate); // would work.
};
}
};
});
testApp.controller('testCtrl', function ($scope) {
$scope.pkey = 'golden';
$scope.update = function (k) {
// Expecting local variable k, or $scope.pkey to have been
// updated by calls in the directive's scope.
console.log('CTRL:', $scope.pkey, k);
$scope.pkey = 'C+' + k;
console.log('CTRL:', $scope.pkey);
};
});
基本上,我正在设置具有隔离作用域的指令,其中我从父作用域 (pkey) 双向绑定(bind)一个属性 (key),并且还委托(delegate)了一个要调用的方法 (parentUpdate)在父范围的上下文中。
现在,在指令中的 ng-click 事件处理程序期间,我想调用 parentUpdate 方法并在其中做一些事情。当我调用该方法时,我希望父范围的模型已更新。但实际上并非如此,这就是让我感到困惑的地方。
这可能是因为中间缺少一些 $digest 循环,因为用 $timeout 包装 parentUpdate 调用会按预期工作。
有人可以阐明缺少的内容吗?或者如何正确调用 parentUpdate?
最佳答案
好吧,我要解决这个问题......看起来你在 $digest
循环之前改变了孤立的子变量和父变量,其中双向逻辑同步两者。详情如下:
lock()
函数通过单击按钮来执行。这会更新独立的 $scope.key
变量。 注意:这不会立即更新父$scope.pKey
;这通常会在下一个 $digest
周期发生,但在这种情况下不会发生。继续阅读……lock()
中,您正在调用 parentUpdate()
来更新父级的 $scope.pKey
变量。$digest
循环执行。当它循环到父范围时,正确检测到对 $scope.pKey
的更改。$scope.pKey
的更改触发了一个 watch()
,它是由隔离范围中的双向绑定(bind)创建的。 These lines是关键的..watch()
检查双向绑定(bind)的值是否与父级的值同步。如果不是(在这种情况下不是),父级的值将被复制到隔离范围即使隔离范围的值也已更改并且实际上是先更改。 Misko's famous post on Angular data-binding描述了 $digest
循环方法的好处。您在这里看到的是 $digest
改变合并的方法的一个有意识的副作用,其中,正如源代码评论所说,parent changed and it has precedence
...这意味着您的隔离范围的更改会丢失。
您在上面提到的 $timeout()
方法通过仅更改第一个 $digest
周期中的独立范围的值来避免此问题,这允许它被复制到父范围成功,然后调用 parentUpdate()
Often it's desirable to pass data from the isolated scope via an expression and to the parent scope, this can be done by passing a map of local variable names and values into the expression wrapper fn. For example, if the expression is increment(amount) then we can specify the amount value by calling the localFn as localFn({amount: 22}).
这意味着,在第 2 步,您可以通过对象映射为 pkey
传递值,如下所示:
parentUpdate({pkey: 'D+' + $scope.key })
这是更新后的 fiddle :http://jsfiddle.net/KbYcr/
关于javascript - AngularJS:父范围未在指令中更新(具有隔离范围)双向绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19391773/
我不能解决这个问题。和标题说的差不多…… 如果其他两个范围/列中有“否”,我如何获得范围或列的平均值? 换句话说,我想计算 A 列的平均值,并且我有两列询问是/否问题(B 列和 C 列)。我只希望 B
我知道 python 2to3 将所有 xrange 更改为 range 我没有发现任何问题。我的问题是关于它如何将 range(...) 更改为 list(range(...)) :它是愚蠢的,只是
我有一个 Primefaces JSF 项目,并且我的 Bean 注释有以下内容: @Named("reportTabBean") @SessionScoped public class Report
在 rails3 中,我在模型中制作了相同的范围。例如 class Common ?" , at) } end 我想将公共(public)范围拆分为 lib 中的模块。所以我试试这个。 module
我需要在另一个 View 范围 bean 中使用保存在 View 范围 bean 中的一些数据。 @ManagedBean @ViewScoped public class Attivita impl
为什么下面的代码输出4?谁能给我推荐一篇好文章来深入学习 javascript 范围。 这段代码返回4,但我不明白为什么? (function f(){ return f(); functio
我有一个与此结构类似的脚本 $(function(){ var someVariable; function doSomething(){ //here } $('#som
我刚刚开始学习 Jquery,但这些示例对我帮助不大...... 现在,以下代码发生的情况是,我有 4 个表单,我使用每个表单的链接在它们之间进行切换。但我不知道如何在第一个函数中获取变量“postO
为什么当我这样做时: function Dog(){ this.firstName = 'scrappy'; } Dog.firstName 未定义? 但是我可以这样做: Dog.firstNa
我想打印文本文件 text.txt 的选定部分,其中包含: tickme 1.1(no.3) lesson1-bases lesson2-advancedfurther para:using the
我正在编写一些 JavaScript 代码。我对这个关键字有点困惑。如何在 dataReceivedHandler 函数中访问 logger 变量? MyClass: { logger: nu
我有这个代码: Public Sub test() Dim Tgt As Range Set Tgt = Range("A1") End Sub 我想更改当前为“A1”的 Tgt 的引
我正忙于此工作,以为我会把它放在我们那里。 该数字必须是最多3个单位和最多5个小数位的数字,等等。 有效的 999.99999 99.9 9 0.99999 0 无效的 -0.1 999.123456
覆盖代码时: @Override public void open(ExecutionContext executionContext) { super.open(executio
我想使用 preg_match 来匹配数字 1 - 21。我如何使用 preg_match 来做到这一点?如果数字大于 21,我不想匹配任何东西。 example preg_match('([0-9]
根据docs range函数有四种形式: (range) 0 - 无穷大 (range end) 0 - 结束 (range start end)开始 - 结束 (range start end st
我知道有一个UISlider,但是有人已经制作了RangeSlider(用两个拇指吗?)或者知道如何扩展 uislider? 最佳答案 我认为你不能直接扩展 UISlider,你可能需要扩展 UICo
我正在尝试将范围转换为列表。 nums = [] for x in range (9000, 9004): nums.append(x) print nums 输出 [9000] [9
请注意:此问题是由于在运行我的修饰方法时使用了GraphQL解析器。这意味着this的范围为undefined。但是,该问题的基础知识对于装饰者遇到问题的任何人都是有用的。 这是我想使用的基本装饰器(
我正在尝试创建一个工具来从网页上抓取信息(是的,我有权限)。 到目前为止,我一直在使用 Node.js 结合 requests 和 Cheerio 来拉取页面,然后根据 CSS 选择器查找信息。我已经
我是一名优秀的程序员,十分优秀!