- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个应用程序,应用程序内部有一个注册和登录表单。
使用注册表单,当用户创建帐户时,他们会自动登录。
使用登录表单,用户也可以登录(显然)。
我有两个 Controller :一个用于注册表单,一个用于登录表单。我希望他们能够共享一项服务,“登录”,因为使用这两种形式,用户最终都会登录。
到目前为止,一切正常。我唯一的问题是登录表单会根据数据库异步检查用户的登录凭据,如果处理此请求的 PHP 脚本返回说不匹配,则 Angular 会更新错误消息的模型,如下所示给用户。当“logIn”服务不作为服务使用,而只是复制到两个 Controller 中时,这工作得很好。这是它在“SignupCtrl”中的样子:
.controller('SignupCtrl',['$scope','$http',function($scope,$http) {
$scope.error = false;
$scope.logIn = function() {
var data = // user's login credentials
$http({
// send credentials to server, ask if there's a match
})
.success(function(data) {
if(data.match === false) {
$scope.error = true;
} else {
// start session, redirect to new page, etc.
}
})
}
}]);
然后,在模板内部:
<div ng-show="error">Oops! That email/password doesn't exist.</div>
这很好用;但正如我所说,当“登录”功能用作服务时,情况并非如此。这是因为我无法弄清楚如何在服务中更新 $scope.error
。
我试过使用 $rootScope
(没用):
.service('logIn',[/* injections */, '$rootScope', function(/* injections */, $rootScope) {
return function(email, password) {
// all the same code as before
if(data.match === false) {
$rootScope.error = true; // this does nothing
}
}
}]);
// in the controller (the service is injected in as 'logIn')
$scope.logIn = logIn;
然后,在模板中:
<button ng-click="logIn(user.email, user.password)">Login</button>
用户可以使用该服务正常登录。问题只是用服务更新了 $scope.error
变量。
也许如果我能以某种方式做到这一点,它会起作用:
<button ng-click="logIn(user.email, user.password, $scope)">Login</button>
然后在服务中:
return function(email, password, scope) {
// etc.
if(data.match === false) {
scope.error = true;
}
}
有什么想法吗?谢谢。
澄清一下,根据我对服务
的理解,它们似乎取代了通常声明全局函数的方式,或者只是模块内的整体函数以避免重复一个人的自己。示例:
(function() {
function globalFunction() {
//etc.
}
$('.thing').click(globalFunction);
$('.otherThing').click(globalFunction);
}());
可能还有比这更好的例子,但我认为这个想法很清楚。
这个概念是否类似于在 Angular 中应该如何使用服务?如果没有,是否有更好的方法让我在不使用服务的情况下继续做我想做的事情?
最佳答案
您可以将 $rootScope
传递给服务,但污染您的 $rootScope
通常不是一个好主意,但是在这种特殊情况下您的问题是没有强制执行摘要,因此您的 Controller $scope
不知道更改。在您发布的代码中,如果您将 $rootScope.error
包装在 $rootScope.$apply()
中,一切都会正常进行。但是回调要简洁得多。
我建议您将回调传递给服务方法,并在回调中设置范围变量:
login:function(email,password,callback){
$http({
// send credentials to server, ask if there's a match
})
.success(function(data) {
callback(data.match);
})
}
在你的 Controller 中:
$scope.logIn = function() {
loginServcie.login($scope.email,$scope.password,function(dataIsMatched){
//you now have the result of call, and dataIsMatched is true or false
$scope.error = !dataIsMatched;
})
}
关于javascript - 如何使用服务更改范围变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23201790/
我不能解决这个问题。和标题说的差不多…… 如果其他两个范围/列中有“否”,我如何获得范围或列的平均值? 换句话说,我想计算 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 选择器查找信息。我已经
我是一名优秀的程序员,十分优秀!