ng自定义服务(利用factory)

Posted BD_evel

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ng自定义服务(利用factory)相关的知识,希望对你有一定的参考价值。

ng中我们可以自己定义自己的服务,服务中是一些使用重复率较高的方法。因此有效的使用服务可以提高开发速度。

ng中定义服务的方法有多种,service,factory,provide,在此我只介绍最长用的一种,利用factory

factory会以返回一个对象的形式

app.factory("服务的名字",[function(){

  return{

    getName:function(){

      /........./

    }

  }  

}]);

 

demo:

services/zct_get_my_right.js

define([‘app‘,‘jquery‘], function (myapp) {
myapp.factory(‘get_my_right‘, [function () {
console.log("get_my_right");
var get_my_right={};//自己定义一个对象
//得到用户的权限
get_my_right.get_right=function(obj){
return(JSON.parse(JSON.parse(obj)));
},
get_my_right=function(){
      ....
      return ......
     }

return get_my_right;//返回一个对象
}])
})

 

使用:

  使用服务之前需引入

//创意界面的权限控制器
define(["app",‘services/zct_get_my_right‘], function (myapp) {
myapp.controller(‘ideas_first_ctrl‘,
[‘$scope‘,‘$rootScope‘,‘$state‘,‘get_my_right‘, function (s,rs,$state,getRight) {

var my_right=getRight.get_right(localStorage.permission);
console.log(my_right);
if(my_right.ideas.view){//说明此用户有查看全部创意的权限的
// $state.go("home.ideas.allIdeas",{user_right:JSON.stringify(idea_right)});
s.can_see_all_idea=true;
$state.go("home.ideas.allIdeas");
}
else{//此用户没有查看全部创意的权限
//$state.go("home.ideas.myIdeas",{user_right:JSON.stringify(idea_right)});
s.can_see_all_idea=false;
$state.go("home.ideas.myIdeas");
}
}])
});

 

以上是关于ng自定义服务(利用factory)的主要内容,如果未能解决你的问题,请参考以下文章

自定义服务 factory 和 service

自定义服务与调用--------factory

如何将自定义片段添加到 zen-coding?

angularJS自定义服务的几种方式

AnngularJS---自定义指令

VSCode自定义代码片段——CSS选择器