- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个项目,我需要从 Angular 服务外部访问服务。不幸的是,从 Angular 外部检索的服务似乎与应用程序内部的实例不同。事实上,每次我调用它时它都是一个新实例。我在下面创建了一个示例来演示该问题。
<div ng-controller="controller">
<div>
<span ng-bind="count"></span>
<input type="button" value="Inside" ng-click="inc()"></input>
</div>
<div>
<span id="outside-count">0</span>
<input type="button" value="Outside" onclick="outside()"></input>
</div>
</div>
还有 JavaScript...
angular.module('Services', [])
.service('svc', function() {
var svc = {
count: 0,
increment: function(){svc.count++;}
};
return svc;
});
angular.module('MyApp', ['Services'])
.controller('controller', ['$scope', 'svc', function($scope, svc) {
$scope.count = svc.count;
$scope.inc = function() {
svc.increment();
$scope.count = svc.count;
};
}]);
var outside = function() {
var svc = angular.injector(['ng', 'Services']).get('svc');
svc.increment();
angular.scope().$apply();
document.getElementById('outside-count').innerHTML = svc.count;
};
我期望的是外部计数按钮将增加与我在 ng-controller
中获得的相同的服务对象。但是,它每次都会获取一个新实例,因为连续单击该按钮始终显示 1
。 “内部”按钮继续按预期增加单个服务。
我应该从外部 Angular 访问服务以获取服务的单例实例吗?
Here is a fiddle上面的代码。
最佳答案
Angular 中的服务是单例,因为每个注入(inject)器仅创建一次服务。
angular.injector
但是创建了一个新的注入(inject)器函数。
您需要获取当前应用程序注入(inject)器:angular.element(domElement).injector()
内部保持同步的演示:http://jsfiddle.net/kW2BC/
关于javascript - 为什么从外部 Angular 调用的服务不是单例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23461652/
我最近购买了《C 编程语言》并尝试了 Ex 1-8这是代码 #include #include #include /* * */ int main() { int nl,nt,nb;
早上好!我有一个变量“var”,可能为 0。我检查该变量是否为空,如果不是,我将该变量保存在 php session 中,然后调用另一个页面。在这个新页面中,我检查我创建的 session 是否为空,
我正在努力完成 Learn Python the Hard Way ex.25,但我无法理解某些事情。这是脚本: def break_words(stuff): """this functio
我是一名优秀的程序员,十分优秀!