jjzjj

angularjs-scope

全部标签

javascript - 当表单输入的值无效时,如何防止 AngularJS 解除表单输入值与其模型的绑定(bind)?

我正在使用AngularJS构建表单,我注意到一些我不理解的行为。当我分配ng-minlength=5时作为输入属性,AngularJS解除绑定(bind)该值,直到它比要求的长。这对我来说很不方便,因为我想告诉用户他们输入了多少内容使用user.lifestory.length.为什么AngularJS以这种方式工作?如何防止Angular在值无效时解除绑定(bind)?Lifestory:这里有一个例子:http://jsfiddle.net/J67jm/3/你可以通过填写生活故事字段来看到我所说的行为。 最佳答案 您可以使用{

javascript - 在 Controller 中使用 `this` 作用域时使用 $scope.$watch

我的Angular应用程序中有一个Controller:(function(angular){functionMyController(){this.name='Dave';//Iwanttohavecodelikethis:/*$scope.$watch('name',function(newValue,oldValue){console.log(oldValue,"changedto",newValue);});*/}window.myApp=angular.module('myApp',[]).controller('MyController',[MyController]);}

javascript - 在 AngularJS 上禁用日志记录

我在我的代码中使用angularJS服务进行日志记录($log.error()、$log.debug()、$log.info()等),它工作正常。现在,我正在尝试禁用所有日志。我已经试过了:varapp=angular.module('app',[]);app.config(['$logProvider',function($logProvider){$logProvider.debugEnabled(false);}]);但这没有任何作用,日志继续显示...禁用我放入代码中的所有angularJS日志的最佳方法是什么?编辑:我这样调用日志:(function(){app.contro

javascript - AngularJS 测试 $httpBackend.flush() 导致错误

我正在尝试使用jasmine对我为Spotify创建的AngularJS服务进行一些测试。但是在测试promises时,我的测试总是出错。我的测试目前是这样的:describe('Spotify.search',function(){var$httpBackend;var$rootScope;varSpotify;varapi='https://api.spotify.com/v1';beforeEach(inject(function(_Spotify_,_$httpBackend_,_$rootScope_){Spotify=_Spotify_;$httpBackend=_$htt

javascript - 将对象从 jade 传递到 angularjs 模板

我正在尝试将对象从Node传递到客户端,如下所示render:function(req,res){res.render('auth',{userData:req.session.user});}在我的auth.jade中,代码如下script.vardata=!{JSON.stringify(userData)}console.log(data)window.top.location='/profile'所以我将应用程序重定向到我在routeProvider中使用angularjs定义的新路由app.config(['$routeProvider','$locationProvider

javascript - 如何覆盖/更改值提供者的 AngularJS 值

我想覆盖值-angular.module("data",[]).value('apiBase','/api1/data')在运行时,我尝试修改它-angular.module("data").value('apiBase','/someotherapi/data')在某些服务/Controller中,但它失败了,它没有覆盖apiBase的值。我试图在我的Controller中注入(inject)apiBase并更改它。angular.module('data').controller(function(apiBase){apiBase='/someotherapi/data'})它失败

javascript - ng-include 内部和外部的 $scope 行为不同

所以我做了一些实验来在2个不同的选择框上创建一个ng-change行为,同时携带相同的$scope。一个在ng-include指令内,同时另一个在ng-include指令之外,有趣的部分是虽然当我实现数据绑定(bind)时它结果没问题,但是当我试图查看我的控制台选项卡时它返回不同在ng-include指令之外的那个没问题,而在ng-include指令里面的那个总是返回值'a'或静态值这是index.html模型AB{{list}}//thisscopecariestest.html这是test.html模型AB{{list}}这是Controllervarapp=angular.mod

javascript - AngularJS:ng-repeat 中的 ng-model setter

关于如何在ng-repeat中获取ng-model的值,我找到了一些很好的答案,但是到目前为止,我还没有找到任何覆盖二传手的东西。假设我有这样的东西:如果我只有一个输入框,我会使用类似this的东西:...var_val='';$scope.itemTitle=function(val){returnangular.isDefined(val)?(_val=val):_val;}...但是,这会改变每个输入框的值。是否可以定义变量和setter,可能使用数组?或者是否有更好的方法在ng-repeat中获取和设置输入框? 最佳答案 a

javascript - Angular JS - 指令中的数据绑定(bind)不起作用

我有一个指令内的数据绑定(bind)问题,该指令调用另一个指令。这是主要指令:varapp=angular.module('app');app.directive("myMainDirective",function($http){return{scope:{paramId:'='},link:function(scope){$http.get('some/url/'+scope.paramId+'.json').success(function(data){scope.idFromServer=data;});},template:''}});这是另一个指令:varapp=angul

javascript - TypeError : (intermediate value)(intermediate value). 成功不是一个函数(angular)

我很难理解这个错误...我不太明白为什么它不是函数...angular.module('mkApp').factory('mkService',function($http,$log){functiongetLookUp(successcb){$http=({method:'GET',url:'api/Entries/'}).success(function(data,status,header,config){successcb(data);}).error(function(data,status,header,config){$log,warn(data,status,heade