AngularJS基于provider实现全局变量的读取和赋值方法
网络编程 2021-07-04 18:32www.168986.cn编程入门
这篇文章主要介绍了AngularJS基于provider实现全局变量的读取和赋值方法,结合实例形式分析了AngularJS全局变量的声明、赋值、读取等相关使用技巧,需要的朋友可以参考下
本文实例讲述了AngularJS基于provider实现全局变量的读取和赋值方法。分享给大家供大家参考,具体如下
简单全局变量的设置
1,通过var 直接定义global variable,这根纯js是一样的。
2,用angularjs value来设置全局变量 。
3,用angularjs constant来设置全局变量 。
示例代码如下
在app文件中,声明三种变量
'use strict'; / App Module / var test2 = 'tank'; //方法1,定义全局变量 var phonecatApp = angular.module('phonecatApp', [ //定义一个ng-app 'ngRoute', 'phonecatControllers', 'tanktest' ]); phonecatApp.value('test',{"test":"test222","test1":"test111"}); //方法2定义全局变量 phonecatApp.constant('constanttest', 'this is constanttest'); //方法3定义全局变量
在controller中对全局变量进行读取
'use strict'; / Controllers / var phonecatControllers = angular.module('phonecatControllers', []); phonecatControllers.controller('PhoneListCtrl', ['$scope','test','constanttest', function($scope,test,constanttest) { $scope.test = test; //方法2,将全局变量赋值给$scope.test $scope.constanttest = constanttest; //方法3,赋值 $scope.test2 = test2; //方法1,赋值 }]);
注意事项
var test;设置后,无需在controller声明的时候注入,直接使用即可。
value和contant,在app中初始化后,需要在controller声明时候注入到controller中,才能够使用。
这三种方式都存在一个问题,即只能够读取全局变量,无法对全局变量进行修改赋值。在很对业务逻辑中无法满足业务需求。
使用provider实现全局变量。
步骤与上面的value和contant差不多。
在app中完成声明和初始化。
<script type="text/javascript"> var app = angular.module('ngRouteWxCtb', ['ngRoute','ngCookies']); //TODO:provider of globle uid and weixinIsInit param app.provider('userService', function () { var data = {uid:0,weixinIsInit:false}; var f = function (uid,weixinIsInit) { if (uid != 0) { data.uid= uid; data.weixinIsInit = weixinIsInit; } return data; }; this.$get = function () { return f; }; }); </script>
在controller声明的时候,注入。
app.controller('myCtrl1', function ($scope, userService) { var data = userService(0, 0, false);//读取全局变量 })); app.controller('myCtrl2', function ($scope, userService) { var data = userService(123, 111, true);//设置全局变量 }));
通过provider提供的get方法,实现参数的读取和赋值。
注意事项
代码中,我们对provider 的赋值操作进行了取巧设计,当第一个参数等于0的时候,默认是读取,当第一个参数不为0的时候,实现的是设置后进行读取。这样,公用一个get方法即可,无需增加新的方法。
更多关于AngularJS相关内容感兴趣的读者可查看本站专题《》、《》及《》
希望本文所述对大家AngularJS程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程