草庐IT

scope1_method

全部标签

javascript - $scope 的方法通过 ng-click 调用 : executed twice by IE

在我的Controller中:$scope.homeAction=function(){console.log("HomeAction");};在我看来:callhomeAction()单击按钮时,Chrome和Firefox会按预期执行该方法,但IE会执行两次。知道为什么吗?这是一个重现问题的plunker:http://plnkr.co/edit/pedZKjIVGDAYfMl0ZphJ. 最佳答案 只需将type="button"添加到您的按钮,它就会被修复。默认行为是提交,这显然会扰乱您的代码。callhomeAction(

javascript - 我应该总是将函数绑定(bind)到 $scope 对象吗?

当我创建Controller时,我总是将函数添加到$scope对象,像这样:functionDummyController($scope){$scope.importantFunction=function(){/*...*/};$scope.lessImportantFunction=function(){/*...*/};$scope.bussinessLogicFunction=function(){/*...*/};$scope.utilityFunction=function(){/*...*/};}当然,我会很好地封装我的Controller,确保业务逻辑位于适当的组件(通

javascript - 使用 Meteor.methods 和 Meteor.call

我有以下服务器代码:Meteor.startup(function(){Meteor.publish("AllMessages",function(){lists._ensureIndex({location:"2d"});returnlists.find();});});Meteor.methods({getListsWithinBounds:function(bounds){lists._ensureIndex({location:"2d"});returnlists.find({"location":{"$within":{"$box":[[bounds.bottomLeftLn

javascript - KnockoutJS fromJS 不工作 TypeError : Cannot call method 'fromJS' of undefined

我使用knockoutJS,当我使用“fromJS”时出现以下错误TypeError:Cannotcallmethod'fromJS'ofundefined我的JavaScript代码$(document).ready(function(){varPersonModel=function(data){ko.mapping.fromJS(data,{},this);};vardata=$.getJSON("http://localhost:40913/candidate/index/1",function(data){viewModel=newPersonModel(data);ko.a

javascript - 下拉 Javascript 错误 : object doesn't support property or method 'matches'

我正在使用以下JavaScript下拉菜单,它在除新的WindowsEdge之外的所有浏览器中都能完美运行。它显示这个错误:SCRIPT438:Objectdoesn'tsupportpropertyormethod'matches'脚本:/*Whentheuserclicksonthebutton,togglebetweenhidingandshowingthedropdowncontent*/functionmyFunction(){document.getElementById("myDropdown").classList.toggle("show");}//Closethed

javascript - IE9 中的 Jquery 2.1.1 出现错误 : 0x800a01b6 - Microsoft JScript runtime error: Object doesn't support property or method 'addEventListener'

使用VisualStudio2013,我将一个混合的Asp.NetWebforms/MVC3Web应用程序迁移到Asp.NetWebforms/MVC5.1。作为迁移的一部分,我使用NuGet包管理器将Jquery从1.9.1升级到2.1.1。当我在Chrome的VisualStudio2013调试器中运行应用程序时,我没有遇到任何问题。当我在IE9的VisualStudio2013调试器中运行应用程序时(兼容模式未打开),首先加载带有这两个脚本标记的母版页:由于此Javascript错误而失败:Unhandledexceptionatline3425,column4inhttp://

javascript - 使用 Jasmine 2.0 对 $scope.$evalAsync 函数进行单元测试

我正在尝试对$scope.$evalAsync函数进行单元测试。这是我的代码:$scope.$evalAsync(function(done){//enablethepopoverplugindone();jQuery('[data-toggle="popover"]').popover();$scope.isKioskIdLoaded.state=true;});我很难理解如何让evalAsync在我的Jasmine测试中运行。我正在尝试利用Jasmine2.0中的done()函数。 最佳答案 您需要将$scope.$digest

javascript - $scope.$on ('$destroy' , ...) 的事件处理程序是否被销毁?

今天遇到了一个非常“深奥”的Angular问题,我找不到答案。来自$scope文档,您可以在"$destroy"上注册一个事件处理程序,它会在作用域销毁之前立即调用。这样,您就可以像这样注销事件处理程序:varderegister=$scope.$on('myCustomEvent',function(){//dosomecrazystuff});$scope.$on('$destroy',function(){deregister();});但是,$scope.$on('$destroy',...)必须创建自己的处理程序。它是自动销毁的,还是必须执行以下操作才能销毁它?vardere

javascript - 在指令中调用 $compile($element)($scope) 的目的是什么

Angular码placedonjsfiddle关于自定义指令,它使用$compile($element)($scope)并导致ng-click操作发生两次:我的问题是:我想了解为什么会发生ng-click操作两次?调用$compile($element)($scope)的目的是什么?如果不调用会发生什么,在什么情况下应该调用叫什么?以下是详细信息以及我目前收集到的信息:我想明白,为什么ng-clickAction会发生两次?下一行显示了自定义指令“hello”和ng-click按钮。自定义指令调用$compile($element)($scope)并且这是导致操作被触发两次的行,但我

javascript - 未捕获的类型错误 : Cannot call method 'on' of undefined - Backbone. js

我的应用程序出现错误,不知道为什么。UncaughtTypeError:Cannotcallmethod'on'ofundefined它发生在我的CollectionView上,遵循代码:App.WorkoutsView=Backbone.View.extend({initialize:function(){this.collection.on('add',this.addOne,this);this.collection.on('reset',this.addAll,this);},render:function(){this.addAll();returnthis;},addAll