angularjs 设置全局变量的3种方法

angularjs自身有二种,设置全局变量的方法,在加上js的设置全局变量的方法,总共有三种。要实现的功能是,在ng-app中定义的全局变量,在不同的ng-controller里都可以使用。

1,通过var 直接定义global variable,这根纯js是一样的。

2,用angularjs value来设置全局变量 。

3,用angularjs constant来设置全局变量 。

下面用一个例子,来说明,上面3种方法:

实例:

1,在app模块中,定义全局变量

查看复制打印?

  1. ‘use strict‘;
  2. /* App Module */
  3. var test2 = ‘tank‘;         //方法1,定义全局变量
  4. var phonecatApp = angular.module(‘phonecatApp‘, [     //定义一个ng-app
  5. ‘ngRoute‘,
  6. ‘phonecatControllers‘,
  7. ‘tanktest‘
  8. ]);
  9. phonecatApp.value(‘test‘,{"test":"test222","test1":"test111"});  //方法2定义全局变量
  10. phonecatApp.constant(‘constanttest‘, ‘this is constanttest‘);    //方法3定义全局变量
  11. phonecatApp.config([‘$routeProvider‘,                //设置路由
  12. function($routeProvider) {
  13. $routeProvider.
  14. when(‘/phones‘, {
  15. templateUrl: ‘partials/phone-list.html‘      //这里没有设置controller,可以在模块中加上ng-controller
  16. }).
  17. when(‘/phones/:phoneId‘, {
  18. templateUrl: ‘partials/phone-detail.html‘,
  19. controller: ‘PhoneDetailCtrl‘
  20. }).
  21. when(‘/login‘, {
  22. templateUrl: ‘partials/login.html‘,
  23. controller: ‘loginctrl‘
  24. }).
  25. otherwise({
  26. redirectTo: ‘/login‘
  27. });
  28. }]);

2,在controller中调用全局变量

查看复制打印?

  1. ‘use strict‘;
  2. /* Controllers */
  3. var phonecatControllers = angular.module(‘phonecatControllers‘, []);
  4. phonecatControllers.controller(‘PhoneListCtrl‘, [‘$scope‘,‘test‘,‘constanttest‘,
  5. function($scope,test,constanttest) {
  6. $scope.test = test;                   //方法2,将全局变量赋值给$scope.test
  7. $scope.constanttest = constanttest;   //方法3,赋值
  8. $scope.test2 = test2;                 //方法1,赋值
  9. }]);

3,在html中看一下效果

查看复制打印?

  1. <div data-ng-controller="PhoneListCtrl">
  2. {{test.test1}}
  3. {{constanttest}}
  4. {{test2}}
  5. </div>
  6. 结果:test111 this is constanttest tank

其实我们可以通过其他方法来实现全局变量,例如:angularjs factory的功能。

83

地址:http://blog.51yip.com/jsjquery/1601.html

时间: 2024-08-04 18:12:47

angularjs 设置全局变量的3种方法的相关文章

iphone 设置全局变量的几种方法

一般的软件 都有一个 登陆的功能,然后根据登陆的UserID 查看不同的信息,这也就意味着UserID 是一个 全局变量,之后的类我们都需要用到,所以 这也就需要定义 全局变量来解决问题,这里提供2种方法: 第一种 把全局变量设置到AppDelegate中 使用很简单,在AppDelegate.h文件中 写入你需要的变量,在AppDelegate.m中加入 @synthesize +你刚刚在 .h中加入的变量 需要使用的时候倒入 头文件 添加以下代码: AppDelegate *delegate

Ionic 设置全局变量,三种方法设置图片一种是直接增加,一种是replace,第三种是管道和第二种类似

原文地址:https://www.cnblogs.com/sugartang/p/11432422.html

suse下设置IP的两种方法

/Files/yzhxhwt/DB_51aspx.rar 第一种SUSE Linux IP设置方法ifconfig eth0 192.168.1.22 netmask 255.255.255.0 uproute add default gw 192.168.1.2 释义:#IP配置,包括子网掩码,看情况修改eth0和192.168.1.22 #网关修改 ,看情况修改192.168.1.2 第二种SUSE Linux IP设置方法 在suse操作系统中每个网卡都有一个配置文件,在/etc/sysc

定义c/c++全局变量/常量几种方法的区别(转载)

出自:http://www.cnblogs.com/yaozhongxiao/archive/2010/08/08/1795338.html 在讨论全局变量之前我们先要明白几个基本的概念:  1. 编译单元(模块): 在ide开发工具大行其道的今天,对于编译的一些概念很多人已经不再清楚了,很多程序员最怕的就是处理连接错误 (link error)  因为它不像编译错误那样可以给出你程序错误的具体位置,你常常对这种错误感到懊恼,但是如果你经常使用 gcc,makefile等工具在linux或者嵌入

[分享]Ubuntu 中设置源的几种方法

Ubuntu里的许多应用程序软件包,是放在网络里的服务器上,这些服务器网站,就称作“源”,从源里可以很方便地获取软件包, 下面的方法选一种即可,我们来看这个练习: 1.简单设置源 8)连接好网络后先换源,在左边的快速启动面板中点击“软件中心”按钮,再把鼠标移到最上边出现菜单栏,点“编辑-软件源”: 2)先出来一个密码输入框,输入自己密码后,点绿色“OK”按钮确定,进入源面板: 3)进入源面板后,把几个勾都打上,点击下面的下拉列表,选择 server for 中国(china),即中国的源: 4)

Kettle_设置变量的两种方法

一个复杂的kettle作业一般包括很多子作业和转换,在主作业Start后通常会添加一个[设置变量]的流程,该流程的功能是为所有流程的公共变量设置通用值.       主作业添加的[设置变量]针对的是所有流程,如果需要运行某个在作业,就需要将其引用的变量值改为常量才能运行,想当年麻烦,本文介绍两种方法规避该问题 方法一:在子作业中添加设置变量流程 下图中table changlog exists?流程使用变量${cl},但是设置${cl}变量的值在主作业执行,所以执行本作业时会报错  解决方法:在

为maven插件设置参数的三种方法

很多的maven插件都提供了丰富的可选参数,用户可以通过设置特定的参数值来控制maven插件的行为.设置插件参数的方法主要有三种,分别是命令行设置,POM文件中为插件设置全局参数和POM文件中为插件设置任务参数. 第一种,命令行设置.这种设置方式是在使用命令行调用maven生命周期阶段或者插件目标时设置插件参数的方法,其形式是"-D参数键=参数值",可以设置多个,每个参数键值对都要使用"-D"参数,相互之间以空格分隔.这种设置方式将参数设置为Java系统属性,mav

iOS设置圆角的四种方法

一.设置CALayer的cornerRadius cornerRadius属性影响layer显示的background颜色和前景框border,对layer的contents不起作用.故一个imgView(类型为UIImageView)的image不为空,设置imgView.layer的cornerRadius,是看不出显示圆角效果的,因为image是imgView.layer的contents部分. 这种情况下将layer的masksToBounds属性设置为YES,可以正确的绘制出圆角效果.

php设置时区的两种方法

php5后都要自己设置时区,要么修改php.ini的设置,要么在代码里修改. 在PHP.INI中设置时区 date.timezone = PRC 在代码中设置时区 1 date_default_timezone_set('Asia/Shanghai');//'Asia/Shanghai'   亚洲/上海 2 date_default_timezone_set('Asia/Chongqing');//其中Asia/Chongqing'为“亚洲/重庆” 3 date_default_timezone