$scope vs var in AngularJS

后端 未结 5 1834
暖寄归人
暖寄归人 2020-12-05 17:38

I\'ve been using var and $scope.varname and both work fine in AngularJS. I was wondering if there was a difference between the two functionally, and what best practice was i

相关标签:
5条回答
  • 2020-12-05 17:52

    $scope bind value to the view and var is the local variable to the application.

    0 讨论(0)
  • 2020-12-05 17:55

    Yes! $scope variables bind to the view where as var does not and is local to the function it was declared in!

    var x = 3;
    $scope.y = 3;
    
    {{x}} - undefined
    {{y}} - 3
    
    0 讨论(0)
  • 2020-12-05 17:55

    The technical implications of using var and $scope have been described by @tymeJV and others. I think the next logical question answer is: When do I use either?

    TL;DR - if you do not use a variable in a view (e.g. {{myVar}} ), use var.

    The reason is two fold:

    1. Encapsulation - hide state that is not necessary to the view. This will prevent unintended modifications of the variable.

    2. Performance (prevent extra digest cycles) - Angular performs "dirty state" checking on variables. Modifying a variable that's not used in the view may cause extra digest cycles unnecessarily. In an application with a couple of ng-repeats and a bunch of watches, this can have a huge impact.

    0 讨论(0)
  • 2020-12-05 17:57

    1 - $scope, is the glue between your controller and your view/model , when you are defining a variable/function to the $scope of a controller, your whole view , which this controller controls it ! , can see that variable/function . Where a pure variable just works in that controller , not even the view of that controller!

    2- Every thing that has been defined to the $scope , is manupulatable from the outside of the controller , throughout the Directives , Services , your html view ... , while a pure variable is NOT;

    0 讨论(0)
  • 2020-12-05 18:08

    Simply spoken - all variables you define on $scope, e.g. in your controller, are available in your html markup. in case you need a variable just inside your js functions, you can declare it with var, they are only locally available. Same with functions.

    0 讨论(0)
提交回复
热议问题