- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试重构一个应用程序,该应用程序一直在使用 Ajax 获取一些服务器数据,然后将其附加到 $rootScope
以便在引导应用程序之前获取 Controller 和服务,我一直在尝试使用 $q
plnkr: http://plnkr.co/edit/22yQUlyE9nbQ0WVjxWxY
在那个 plnkr 中,我试图让服务返回一些数据供一些 Controller 使用。
app.service('data', function($q, $window, $timeout) {
var promise = $q.defer();
promise.promise.foo = 'Dang!';
$timeout(function() {
console.log('resolve promise');
promise.resolve({
foo: 'bar',
baz: 'zot'
});
}, 1000);
console.log('return promise');
return promise.promise
});
我正在像这样使用 $routeProvider 的 resolve-property
app.config(function($routeProvider) {
$routeProvider.when('/', {
controller: 'MainController',
templateUrl: 'data.html',
resolve: {
data: 'data'
}
});
});
但是,当我尝试在我的一个 Controller 中将已解决 promise 的“foo”属性分配给 $scope 时,它就出错了。
app.controller('MainController', function($scope, data) {
$scope.main = data.foo;
});
app.controller('Controller1', function($scope, data) {
$scope.controller1 = data;
});
$scope
在 promise 解析时不会更新,实际 promise 对象的 foo
属性最终在 $scope
上作为可以在http://plnkr.co/edit/22yQUlyE9nbQ0WVjxWxY?p=preview上看到
那么我是否正在做一些我绝对不应该在这里做的事情,通过将 promise 的属性分配给 $scope
?我的印象是路由的 resolve-property 意味着在 promise 被解决之前,什么都不应该被初始化。
最佳答案
看起来发生的事情是时间问题。实例化服务时,它会设置超时。然后将 Controller 实例化,将 $scope.main
设置为 data
的属性,但不设置为 data
引用的对象。
当您将此嵌套属性分配给另一个引用时,您将失去跟踪父引用更改的能力,因为对该属性的此引用将始终指向旧值。当您在 Controller1
中引用同一对象 (data
) 时,您不会遇到此问题,因为引用所指向的对象的属性只是被覆盖了。如果 resolve 方法正在将新对象写入数据,从而更改引用,您会看到同样的问题。
分为几个步骤:
1) 数据服务被实例化并返回一个对象,该对象具有单个属性 foo
,指向一个值为 Dang!
的字符串对象。
2) MainController 被实例化,并将作用域的 main
属性设置为数据服务的 foo 属性中保存的对象。这是重要的部分,因为主要属性只知道对象 Dang!
。
此外,Controller1 被实例化并将作用域的 controller1
属性设置为作为数据服务的对象。
3) 计时器触发并将数据对象的属性覆盖为其他一些属性。由于 data
中的对象未被替换,controller1
可以看到每个属性的新值。由于 main
指向包含值 Dang!
的对象,因此它没有任何变化。如果它引用的对象的值发生变化,它只会注意到变化,并且由于 javascript 中的字符串值是不可变的,因此它无法改变。
要解决您的情况,如果您希望范围的属性随着服务的变化而变化,您需要绑定(bind)到您的服务并在表达式中引用这些属性。
关于javascript - Angular .js : Is it not possible to assign properties of a resolved promise to $scope?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16811767/
我使用 resolver() 作为 socket() 的替代方法,因为我发现当多个连接建立到不同的 IP 时,它最终会停止工作。 无论如何它会向我返回一个警告,我应该使用 dns.resolver.R
我有这个代码: var promise1 = new Promise(function(resolve, reject) { setTimeout(() => { console
我仍在学习 PHP,我认为我不是母语人士,这并不难理解。 此时,看了一大堆文档,跳入了深水区,于是打开Laravel源文件,一个接一个地看,试图更好地理解MVC的整个实现,包括路由、中间件如何组合成一
public JsonResult GetEvents(double start, double end) { var userName = Session["UserName"] as st
我正在使用 bluebird,我看到了两种将同步函数解析为 Promise 的方法,但我不明白这两种方法之间的区别。看起来堆栈跟踪有点不同,所以它们不仅仅是一个别名,对吧? 那么首选的方式是什么? 方
我写了下面的代码: function readFile(path) { return new Promise(function(resolve, reject){ if(!fs
我正在使用 bluebird,我看到了两种将同步函数解析为 Promise 的方法,但我不明白这两种方法之间的区别。看起来堆栈跟踪有点不同,所以它们不仅仅是一个别名,对吧? 那么首选的方式是什么? 方
在某处读过这个例子: return new Promise( (resolve, reject) => { fs.readFile(file, (err, data) => { if (e
我刚开始学习 React,我一直在尝试让我的 React 应用程序连接到我的数据库 var mysql = require('mysql'); var con = mysql.createConnec
我需要从 $http 调用中返回一个 promise 中的自定义响应,以便我可以链接更多调用。我有两个可用的实现。有人可以解释两者之间的区别,并争论其中一个更好吗? 在 fooService.js 实
免责声明:这里实际上提出了两个问题,但我觉得它们密切相关。 我正在尝试将 promise 对象传递给指令,并且我想在 promise 解析后立即在指令中运行一些初始化代码。 在我的 Controlle
我正在尝试创建类似于 this code 的东西在 boost.asio 示例中找到。 套接字.h: class some_class { private: ... boost
正如我们所知,Promise 构造函数采用一个执行函数,该函数具有两个参数,我们使用它们来生成成功案例或失败案例。今天我在编程,我被卡住了,但后来我解决了这个问题,但我发现了一件事需要理解。 有什么区
我认为 Promise.resolve 和 new Promise(resolve) 可以互换。 考虑一下: A. new RSVP.Promise(function (resolve, reject
我下载了一个 Java 项目,我想研究并从中学习一些东西。当我在另一台计算机上下载它时效果很好,但是当我在我的计算机上尝试时,几乎每个声明和导入都会给出错误消息“* cannot be resolve
我昨天看到了一些有趣的编译器行为,我想我明白为什么会这样,但我想确定一下。所以,我不会写我的推理,只写事实。 请注意,我使用 vector 而不是 string 并不是错字。我是故意这样做的,这样编译
我正在尝试运行 Ember 测试,它给出了这个错误,提示无法找到从 `AppName/resolver 导入的模块 ember-resolver。 我不确定是什么原因造成的。我正在使用 Ember-c
Code#1 和 Code#2 的区别在于:Code#1 使用 resolve(p) 而 Code#2 使用 p.then(()=>resolve()) 。我希望输出序列是不变的,但它们会生成不同的序
IntelliJ IDEA 无法解析内置 JVM 类型和方法的常见原因有哪些?例如,当我将鼠标悬停在 String 上时,工具提示显示“无法解析符号“String””。就好像 IntelliJ 不知道
IntelliJ IDEA 无法解析内置 JVM 类型和方法的常见原因有哪些?例如,当我将鼠标悬停在 String 上时,工具提示显示“无法解析符号“String””。就好像 IntelliJ 不知道
我是一名优秀的程序员,十分优秀!