当前位置: 首页 > 面试题库 >

为何Angular在这里不随范围更新?

冷正信
2023-03-14
问题内容

我对Angular很陌生,并且使用firebase作为后端。我希望有人可以调试此问题。当我第一次进入我的页面
**www.mywebsite.com/#defaultHash时** ,数据不会加载到DOM中,但在访问另一个哈希链接并返回之后,它确实会加载。

我的控制器是这样的:

/* initialize data */

var fb = new Firebase('https://asdf.firebaseio.com/');

/* set data to automatically update on change */

fb.on('value', function(snapshot) {

  var data = snapshot.val();
  $scope.propertyConfiguration = data.products;
  console.log($scope.propertyConfiguration);
  console.log("Data retrieved");

});

/* save data on button submit */

$scope.saveConfigs = function(){

  var setFBref = new Firebase('https://asdf.firebaseio.com/products');
  setFBref.update($scope.propertyConfiguration);
  console.log("configurations saved!");

};

我有3条哈希路由,分别是“ Shared”,“ Registration”和“ Home”,否则else.redirectTo设置为“
Shared”。(它们都使用此控制器)这是发生的错误:(所有“ links”都是href =“ #hashWhereever“

1)转到 **website.com/#Shared** 或刷新。控制台日志$
scope.propertyConfiguration和“已检索数据”。DOM什么也没显示。

2)单击进入 **website.com/#Registration** ,控制台将正确记录$ scope数据,正确加载了DOM。

3)单击返回 **website.com/#Shared** ,控制台会正确记录$ scope数据,但这次DOM已正确加载。

4)刷新当前正确加载的 **website.com/#Shared** 。DOM元素消失。

由于$
scope.data在这里所有情况下都是正确的,因此Angular是否应确保DOM正确反映了模型?为什么只有当我从另一个链接单击页面时,DOM才能正确加载。

我可以通过添加window.location.hash =“ Shared”来“修复”它,但它会在控制台中引发大量错误。

修正 :(sorta)

函数$ scope。$ apply()强制视图与模型同步。我会自己回答这个问题并关闭它,但是我仍然想知道为什么当我为$
scope正确分配一个值时视图不能正确加载。如果Angular的“脏检查”在可能的情况下更改了模型,是否没有为$ scope超值赋值?


问题答案:

Angular无法知道您已为$ scope.variable分配了一个值。这里没有魔术。当您运行指令(ng-click / ng-
submit)或Angular内部函数时,它们都会调用$ apply()并触发摘要(检查脏标志和更新例程)。

比$ apply可能更安全的方法是使用$timeout。当前,如果您在Firebase中调用写操作,它可能会同步触发事件侦听器(child_added,child_changed,value等)。这可能会导致您仍然在$apply范围内调用$ apply。如果执行此操作,则会引发错误。$ timeout绕过了这个。

有关摘要和$timeout的主题,请参见此SO问题。

《Angular开发人员指南》中的此文档介绍了编译的工作方式;对于任何认真的Angular开发人员来说,都是非常好的背景知识。

另外,您可以通过使用Angular的官方Firebase绑定来节省大量精力,该绑定已经考虑了所有这些实现细节。

模糊相关的注意事项:在不久的将来,Angular将能够利用Object.observe魔术来处理这些更新。



 类似资料:
  • 问题内容: 我需要从指令中的父控制器继承范围。我不一定要离开范围:false。我也不一定要使用孤立的作用域,因为要获得我确实关心的值正确链接(需要在父控制器中考虑很多值),就需要大量的工作。 如果要更新父范围,在我的指令中使用是否有意义? 请检查小提琴 问题答案: 尽管@user1737909已经引用了SO问题来阅读(AngularJS中范围原型/原型继承的细微差别是什么?它将解释该问题并建议各种

  • 问题内容: 尽管在ChildCtrl中实例化了一个“新”变量,我如何进行变量更改并将其轻松传播回ParentCtrl?加分点数最少,甚至没有$ on和$ watch(使其更易于实现) ParentCtrl ChildCtrl / ChildCtrl2 / ChildCtrl3 / ChildCtrl4 视图 我的ChildCtrl的区别就足够大了,我无法轻松抽象出主布局和ng-view,但是它们都

  • 我试着玩pyplay,我可以在屏幕上画一个精灵的形象。我试图通过改变x和y变量来移动WASD中的精灵。 当我运行程序时,精灵会绘制,但当我按正确的键时不会移动。 编辑:我添加了一个更新方法,moveY参数说它不在那里,尽管它显然在那里,为什么? 这是代码:

  • 如果我做:Math.random() * 4-2 这会让我得到一个范围(-2,2),2是排他性的吗?我认为这是正确的,但我很少得到正数(是的,我知道这是一个随机算法,我们必须无限随机地生成它才能感觉到,但我只是想确保) 新问题 如果我想要所有从-1到1的随机有理数,两个边界都包括在内,那么这条线是否有效:Math.random() * 2.00000000000000001 - 1; 我查了一下,

  • 问题内容: 页面刷新时,我试图从sessionStorage检索搜索和过滤数据。 sessionStorage.restorestate返回未定义,有人知道为什么吗? Plunkr:http://plnkr.co/edit/oX4zygwB0bDpIcmGFgYr?p = preview 问题答案: 当您在Angular应用程序中刷新页面时,就像完全重新启动应用程序一样。因此,要从会话存储中还原,

  • 问题内容: 我是Angular的新手,所以我想按照教程学习,只是不懂而已。令我困惑的是点符号: 在任何输入框中键入一个值将更新所有其他输入框。因此,我认为这是控制器外部的第一个声明将输入元素值绑定到根作用域中的data.message模型。我不明白里面的绑定是如何从中读取值的。根作用域,为什么插入作用域内的值将显示在该作用域外的输入框中? 另外如果被删除 那个行为不见了,怎么会这样? 问题答案: