林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

摘要:本文要讲讲Angular中value vs. constant以及全局变量的设置

本教程使用AngularJS版本:1.5.3

AngularJs GitHub: https://github.com/angular/angular.js/

AngularJs下载地址:https://angularjs.org/

AngualrJS中设置全局变量,即每个Controller中都可以访问的变量,主要有以下几种方法:

1、通过var 直接定义global variable,相当于直接用js

2.、用angularjs rootscope来设置全局变量 。

3、用angularjs value来设置全局变量 。

4、用angularjs constant来设置全局变量 。

5、定义服务传值

这里第1种很简单,不说。下面从第2-5来说说

一、angularjs rootscope来设置全局变量

像使用rootscope,笔者的建议是放在run中,这里其这controller中都不用引入rootscope,直接使用需要的全局变量就可以了。

  1. appCommon.run(function($rootScope) {
  2. $rootScope.paginationConf = {
  3. currentPage : 1, // 分页开始
  4. itemsPerPage : 15, // 分页每页显示条数
  5. };
  6. })

然后,其它Controller要用,直接

  1. app.controller('merchantController', function($scope) {
  2. var   limit = $scope.paginationConf.itemsPerPage;
  3. var   pageIndex  = $scope.paginationConf.currentPage;
  1. .......................................
  2. })

这里需要注意的是,每个Controller层都会先在当前的scope找需要的变量,找不到,再到rootscope上去寻找。如果还是找不到,就会报错。

二、用angularjs value来设置全局变量

使用实例如下:

  1. <!DOCTYPE html>
  2. <html lang="zh" ng-app="myApp">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>AngularJS学习</title>
  6. <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
  7. </head>
  8. <body>
  9. <div ng-controller="myCtrl1">
  10. <button ng-click="onclick1()">请点击我1</button>
  11. {{value1}}
  12. </div>
  13. <div ng-controller="myCtrl2">
  14. <button ng-click="onclick2()">请点击我2</button>
  15. {{value2}}
  16. </div>
  17. </body>
  18. <script type="text/javascript">
  19. var app = angular.module('myApp', []);
  20. app.value('myValue',{"value1":"林炳文","value2":"hello world",value3:1});
  21. app.controller('myCtrl1', function($scope,myValue) {
  22. $scope.onclick1 = function() {
  23. $scope.value1 = myValue.value1 + (++myValue.value3);
  24. };
  25. });
  26. app.controller('myCtrl2', function($scope,myValue) {
  27. $scope.onclick2 = function() {
  28. $scope.value2 = myValue.value2 +  (++myValue.value3);
  29. };
  30. });
  31. </script>
  32. </html>

效果:

三、用angularjs constant来设置全局变量

使用实例

  1. <!DOCTYPE html>
  2. <html lang="zh" ng-app="myApp">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>AngularJS学习</title>
  6. <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
  7. </head>
  8. <body>
  9. <div ng-controller="myCtrl1">
  10. <button ng-click="onclick1()">请点击我1</button>
  11. {{value1}}
  12. </div>
  13. <div ng-controller="myCtrl2">
  14. <button ng-click="onclick2()">请点击我2</button>
  15. {{value2}}
  16. </div>
  17. </body>
  18. <script type="text/javascript">
  19. var app = angular.module('myApp', []);
  20. app.constant('myConstant',{"value1":"林炳文","value2":"hello world",value3:1});
  21. app.controller('myCtrl1', function($scope,myConstant) {
  22. $scope.onclick1 = function() {
  23. $scope.value1 = myConstant.value1 + (++myConstant.value3);
  24. myConstant.value1 = $scope.value1;
  25. myConstant.value2 = $scope.value1;
  26. };
  27. });
  28. app.controller('myCtrl2', function($scope,myConstant) {
  29. $scope.onclick2 = function() {
  30. $scope.value2 = myConstant.value2 +  (++myConstant.value3);
  31. myConstant.value1 = $scope.value2;
  32. myConstant.value2 = $scope.value2;
  33. };
  34. });
  35. </script>
  36. </html>

效果:

value与constant区别

value不可在config里注入,constant可以。下面是笔者做的一个测试

  1. app.constant('myConstant',{"value1":"林炳文","value2":"hello world",value3:1});
  2. app.value('myValue',{"value1":"林炳文","value2":"hello world",value3:1});

然后在config来引入:

  1. app.config(function(myValue){
  2. ..
  3. });

报错如下:

如果使用

  1. app.config(function(myConstant){
  2. //可以得到constant定义的'myConstant'
  3. });

一切正常

四、定义服务传值

这是Java中最常用的方法了,其实就相当于定义一个对象的服务中,并设置get/set方法。通过这两个方法来实时更新与获取数据

  1. <!DOCTYPE html>
  2. <html lang="zh" ng-app="myApp">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>AngularJS入门学习</title>
  6. <script type="text/javascript" src="./1.5.3/angular.min.js"></script>
  7. </head>
  8. <body>
  9. <div ng-controller="childCtrl1">
  10. {{name}}
  11. <button ng-click="setName()">set name to jack jack jack</button>
  12. </div>
  13. <div ng-controller="childCtrl2">
  14. {{name}}
  15. <button ng-click="setName()">set name to tom tom tom</button>
  16. </div>
  17. </body>
  18. <script type="text/javascript">
  19. var app = angular.module('myApp', []);
  20. app.factory('dataService', function() {
  21. var name = '我是林炳文';
  22. var service = {};
  23. service.getName = function() {
  24. return name;
  25. };
  26. service.setName = function(newName) {
  27. name = newName;
  28. };
  29. return service;
  30. });
  31. app.controller('childCtrl1', function($scope,dataService) {
  32. $scope.name = dataService.getName();
  33. $scope.setName = function() {
  34. dataService.setName( "set name to jack jack jack");
  35. $scope.name = dataService.getName();
  36. };
  37. });
  38. app.controller('childCtrl2', function($scope,dataService) {
  39. $scope.name = dataService.getName();
  40. $scope.setName = function() {
  41. dataService.setName( "set name to tom tom tom");
  42. $scope.name = dataService.getName();
  43. };
  44. });
  45. </script>
  46. </html>

效果:

跟我学AngularJS:全局变量设置之value vs constant vs rootscope vs 服务[转]的更多相关文章

  1. Adobe Edge Animate –EdgeCommons Log和全局变量设置功能

    Adobe Edge Animate –EdgeCommons Log和全局变量设置功能 版权声明: 本文版权属于 北京联友天下科技发展有限公司. 转载的时候请注明版权和原文地址. 一.Log功能 当 ...

  2. ios开发中全局变量设置和调用方法

    ios开发中,全局变量设置和调用方法如下:在AppDelegate.h文件中设置全局变量:@interface ***AppDelegate{NSString *myName;}@property ( ...

  3. AngularJS动态设置CSS

    使用AngularJS动态设置CSS大致有2种思路: 1.通过动态设置class名称 比如先定义2个样式: .show-true{    display:block;} .show-flase{    ...

  4. 跟我学AngularJs:Controller数据共享、继承、通信使用具体解释

    林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:本文主讲了AngularJs中的Controller中数据共享.继承.通信的具体使用 本 ...

  5. 从0开始学angularjs-笔记02

    上一节课主要跟大家讲解了angularjs的几种特性和看了一个简单的双向绑定的例子.最近都没有时间写博客了....忙成狗呀...今天周末,在写一篇吧~~ 今天主要跟大家详细讲解一下angularjs的 ...

  6. 跟我学AngularJs:AngularJs入门及第一个实例

    林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 摘要:主要给大家介绍了AngularJs及其特性,并以3个实例来做说明. 本教程使用Angul ...

  7. iOS 全局变量设置的几种方式~

    在iOS开发过程中关于全局变量的几个方法 1. 在APPDelegate中声明并初始化全局变量.AppDelegate可以在整个应用程序中调用,在其他页面中可以使用代码段获取AppDelegate的全 ...

  8. 跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别

    林炳文Evankaka原创作品. 转载请注明出处http://blog.csdn.net/evankaka        本教程使用AngularJs版本号:1.5.3        AngularJ ...

  9. postman全局变量设置

    1.点击小齿轮进入到变量添加页面,点击Globals添加全局变量 2.输入变量名称和变量值 3.接口中设置变量

随机推荐

  1. IP地址和子网划分学习笔记之《预备知识:进制计数》

    一.序:IP地址和子网划分学习笔记开篇 只要记住你的名字,不管你在世界的哪个地方,我一定会去见你.——新海诚 电影<你的名字> 在我们的日常生活中,每个人的名字对应一个唯一的身(敏)份(感 ...

  2. 使用 STHTTPRequest 框架解析 Soap1.2 教程

    1.STHTTPRequest框架地址 https://github.com/nst/STHTTPRequest 将 STHTTPRequest .h  STHTTPRequest.m 文件拖入工程中 ...

  3. 用FadingActionBar实现有头图的ActionBar

         FadingActionBar这个开源项目在社区上很火,感觉Google I/O 2014中就有它的身影.今天我们来介绍下这个实用的开源项目. 首先是到这里(https://github.c ...

  4. Java Callable和Future简述

    创建线程的两种方式,一种是直接继承Thread,另外一种就是实现Runnable接口.这两种方式都有一个缺陷就是:在执行完任务之后无法获取执行结果.如果需要获取执行结果,就必须通过共享变量或者使用线程 ...

  5. gunicorn结合django启动后台线程

    preload 为True的情况下,会将辅助线程或者进程开在master里,加重master的负担(master最好只是用来负责监听worker进程) django应用的gunicorn示例:只在主线 ...

  6. SQLServer 日期函数大全 SQLServer 时间函数大全

    原文地址:https://www.cnblogs.com/zhangpengnike/p/6122588.html 一.统计语句 1.--统计当前[>当天00点以后的数据] SELECT * F ...

  7. Android 应用程序之间内容分享详解(二)

    转载请注明出处:http://blog.csdn.net/xiaanming/article/details/9428613 Android 应用程序之间内容分享详解(一) 之前给大家分享了你开发的应 ...

  8. 从 SVM 到多核学习 MKL

    SVM是机器学习里面最强大最好用的工具之一,它试图在特征空间里寻找一个超平面,以最小的错分率把正负样本分开.它的强大之处还在于,当样本在原特征空间中线性不可分,即找不到一个足够好的超平面时,可以利用核 ...

  9. leetcode关于数组的问题

    关于数组的几道面试题 [Leetcode] 628. 三个数的最大乘积 解题思路: 这个一开始我是没想到思路的(除了遍历),因为有正负号的问题,后来看了一下别人的思路然后自己写的,思路是这样的: 三个 ...

  10. Hadoop家族学习路线、实践案例

    作者:Han Hsiao链接:https://www.zhihu.com/question/19795366/answer/24524910来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商 ...