- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个关于 AngularJS 中范围值和分配的快速问题。这可能听起来有点傻,但我对此很好奇。
假设我正在使用 controllerAs
语法,并且我的 Controller 实例是 ctrl
,我已经说过,有些东西,比如带有如下输入的表单:
<form name="ctrl.form">
<input type="text" ng-model="ctrl.firstName" />
</form>
为什么我可以在我的 Controller 中这样做:
if(this.form.$valid) {
//code...
}
但不是这个:
var form = this.form;
if(form.$valid) {
//code
}
第一个示例有效,但第二个示例返回 undefined
。我在这里遗漏了一些简单的变量赋值吗?既然 this.form
持有一个值,为什么它没有分配给 form
?
谢谢!
最佳答案
编辑:
我已经解决了这个问题 - 第二个示例返回未定义的原因是因为变量是在表单提交函数之外分配的。 IE 在完整上下文中,这是我未定义之前的整个文件:
(function () {
'use strict';
//signup controller definition
var SignupCtrl = function($http, $q, User, FormTools) {
var firstName = this.firstName,
lastName = this.lastName,
password = this.password,
form = this.signupForm;
function submitRegistration() {
//check if the form is valid
if(form.$valid) {
console.log("valid");
var user = {
firstName: firstName,
lastName: lastName,
password: password
};
User.createUser(user)
.then(function(response) {
console.log('user saved!');
}, function(err) {
console.error('error, user wasn\'t saved. reason: ' + err);
});
//if the form isn't valid at all
} else {
return false;
}
}
this.submitRegistration = submitRegistration;
};
angular
.module('signup', [])
.config(['$stateProvider', function($stateProvider) {
$stateProvider
.state('signup', {
url: '/signup',
//path relative to index.html
templateUrl: 'modules/signup/signup.html',
controllerAs: 'signup',
controller: 'SignupCtrl'
});
}])
.controller('SignupCtrl', [
'$http',
'$q',
'User',
'FormTools',
SignupCtrl
]);
})();
在我的表单中提交表单时调用了 submitRegistration 函数:
<form ng-submit="signup.submitRegistration()" id="signup-form" name="signup.signupForm" novalidate>
我猜测与表单相关的变量(即 this.firstName
、this.lastName
等)未定义
直到提交函数被调用。为了解决这个问题,我只是交换了分配变量的位置:
(function () {
'use strict';
//signup controller definition
var SignupCtrl = function($http, $q, User, FormTools) {
function submitRegistration() {
var firstName = this.firstName,
lastName = this.lastName,
password = this.password,
form = this.signupForm;
//check if the form is valid
if(form.$valid) {
console.log("valid");
var user = {
firstName: firstName,
lastName: lastName,
password: password
};
User.createUser(user)
.then(function(response) {
console.log('user saved!');
}, function(err) {
console.error('error, user wasn\'t saved. reason: ' + err);
});
//if the form isn't valid at all
} else {
return false;
}
}
this.cool = function() {
console.dir(this.signupForm);
};
this.submitRegistration = submitRegistration;
this.sayHello = User.sayHello;
};
angular
.module('signup', [])
.config(['$stateProvider', function($stateProvider) {
$stateProvider
.state('signup', {
url: '/signup',
//path relative to index.html
templateUrl: 'modules/signup/signup.html',
controllerAs: 'signup',
controller: 'SignupCtrl'
});
}])
.controller('SignupCtrl', [
'$http',
'$q',
'User',
'FormTools',
SignupCtrl
]);
})();
既然变量被移到了局部函数作用域中,它就可以工作了。我猜测在提交表单之前 Controller 无法访问这些变量,但我的看法可能是错误的。
PS:如果你想知道为什么我在 .controller()
之外定义我的 Controller 函数,我发现它更容易调试,因为在出现异常的情况下,我将在我的堆栈跟踪而不是匿名的。
谢谢!
关于javascript - AngularJS 中的 $scope 值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32641583/
我在这里有我的 javascript 代码: define(['controllers/controllers', 'services/alerts'], function(module) {
的意义是什么scope = scope-token *( SP scope-token ) scope-token = 1*( %x21 / %x23-5B / %x5D-7E ) 在 RFC6749
我是 AngularJS 的新手。我试图找出这两个 Controller 定义之间的区别: app.controller('simpleController', ['$scope', function
似乎所有 Guice 的开箱即用 Scope 实现本质上都是基于线程的(或完全忽略线程): Scopes.SINGLETON和 Scopes.NO_SCOPE忽略线程并且是边缘情况:全局范围和无范围。
如果这个问题涉及的是一个常见问题,我很抱歉,但我发现这个问题非常抽象,并且无法真正为其构建一个好的 Google 搜索词。 我试图理解并找到 Maven 中提供的依赖项的用例。我的想法是这样的: 假设
假设我有以下 Controller angular.module('scopeExample', []) .controller('MyController', ['$scope', func
当前在TmThemeEditor上注册的243种配色方案中, 我注意到几乎没有人使用范围选择器运算符。 对于以下情况,运算符非常有用: (text.html | text.xml) & (meta.t
我有一些行为不符合预期的代码......我在 AngularJS Controller 中有一个事件监听器,如下所示: $scope.$on("newClipSelected", function(e
首先,如果帖子太长,我深表歉意。另外,为了以防万一这会以某种方式干扰您可能给我的答案,我不会以通常的方式定义我的 Controller 。相反,我关注http://www.technofattie.c
我有一个模式,其中许多项目类型都是“可编辑的”。这意味着我有很多模板(每种可编辑项目类型一个),这些模板期望具有唯一的字段,但具有通用功能(编辑、保存、取消编辑、删除等)。这些常见功能导致 Contr
$evalAsync 和 $applyAsync 之间有什么区别?我的理解是,当我从指令中使用 $evalAsync 时,表达式将在浏览器呈现之前进行计算。 举个例子,如果我想滚动到页面上的特定位置但
我试图为一个 $scope 变量提供另一个 $scope 变量的值。有人能告诉我出了什么问题吗?查看简单的 plunker 了解详细信息: http://plnkr.co/edit/TlKnd2fM5
我有以下一段 Angular 代码 $scope.prepare = function(){ $scope.elems = [1,2,3]; }; $scope.action = functio
我正在关注 Angularjs 的官方教程,但我陷入了第 2 步。 这是一个片段,我不明白 $scope:scope 的含义, describe('PhoneListCtrl', function()
根据文档, Global: Component is shared among all users. Session: Separate instances of the component are
显示作用域变量,类似于 Angularjs 中的 ng-repeat 元素 这些是我的范围变量 $scope.published = true; $scope.count = 3; 我还有一个名为 l
我是 Angular 的新手,我想在普通的 javascript 中做一些非常简单的事情,但我无法找到如何在 Angular 中正确地做到这一点! 我想设置一个通用函数来清除输入文本字段: 我有这个
在article中发现了这样一个idea : Notice how the value function takes the scope as parameter (without the $ in
注释部分将位于 $scope.$on 下。我需要将 options 返回到我保存 $scope.$emit 的地方。请帮助!!! if (gridConfig.Batch) {
我有一个带有 2 个作用域的 Controller : app.controller('search', function($scope) { $scope.value1 = '';
我是一名优秀的程序员,十分优秀!