对angularJs中2种自定义服务的实例讲解


Posted in Javascript onSeptember 30, 2018

本篇文章介绍2种自定义服务的方式,一种是用factory,一种是用service

一、首先介绍使用factory来进行自定义服务

1.html

<div ng-app="module" ng-controller="ctrl">
  <table border="1" width="600">
    <tr>
      <td>网站名称</td>
      <td>网址</td>
    </tr>
    <tr ng-repeat="v in data">
      <td>{{v.name}}</td>
      <td>{{v.url}}</td>
    </tr>
  </table>
</div>
<script>
  var m = angular.module('module', []);
  //factory定义服务videoServer
  m.factory('videoServer', ['$http', function ($http) {
    return {
      /* 第一种方式      
        get: function (callback) {
        $http({url: '1.php'}).then(function (response) {
          callback(response);
        });
      }*/
      //第二种方式
      all: function () {
        return $http({url: '1.php'});
      }
    };
  }]);
  //在控制器中使用videoServer服务,与自带的服务使用方式一样
  m.controller('ctrl', ['$scope', 'videoServer', function ($scope, videoServer) {
    /*第一种方式
    videoServer.get(function (response) {
      $scope.data = response.data;
    });
    */
    //第二种方式
    videoServer.all().then(function (response) {
      $scope.data = response.data;
    });
  }]);
</script>

1.php

<?php
$data = [
  [ 'name' => '百度', 'url' => 'www.baidu.com' ],
  [ 'name' => '谷歌', 'url' => 'google.com' ],
];
echo json_encode($data,JSON_UNESCAPED_UNICODE);

二、使用service来进行自定义服务

2.html

<div ng-app="module" ng-controller="ctrl">
  <table border="1" width="600">
    <tr>
      <td>网站名称</td>
      <td>网址</td>
    </tr>
    <tr ng-repeat="v in data">
      <td>{{v.name}}</td>
      <td>{{v.url}}</td>
    </tr>
  </table>
</div>
<script>

  var m = angular.module('module', []);
  //service自定义服务videoServer
  m.service('videoServer', ['$http', function($http){
    this.get=function(){
      return $http({method:'get',url:'2.php'}).then(function(response){
        return response.data;
      })
    }
  }])
   //在控制器中使用videoServer服务,与自带的服务使用方式一样
  m.controller('ctrl', ['$scope', 'videoServer', function ($scope, videoServer) {
    videoServer.get().then(function (data) {
      $scope.data = data;
    });
  }]);
</script>

2.php

<?php
$data = [
  [ 'name' => '百度', 'url' => 'www.baidu.com' ],
  [ 'name' => '谷歌', 'url' => 'google.com' ],
];
echo json_encode($data,JSON_UNESCAPED_UNICODE);

以上这篇对angularJs中2种自定义服务的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript十个最常用的自定义函数(中文版)
Sep 07 Javascript
Javascript计算时间差的函数分享
Jul 04 Javascript
浅谈javascript中的instanceof和typeof
Feb 27 Javascript
jquery中$each()方法的使用指南
Apr 30 Javascript
JS实现Fisheye效果动感放大菜单代码
Oct 21 Javascript
jQuery实现的placeholder效果完整实例
Aug 02 Javascript
JS如何设置cookie有效期为当天24点并弹出欢迎登陆界面
Aug 04 Javascript
用JavaScript实现让浏览器停止载入页面的方法
Jan 19 Javascript
Jquery EasyUI $.Parser
Jun 02 jQuery
vue 实现复制内容到粘贴板clipboard的方法
Mar 17 Javascript
jQuery中each方法的使用详解
Mar 18 jQuery
解决layui批量传值到后台操作时出现传值为空的问题
Sep 28 Javascript
angularJs在多个控制器中共享服务数据的方法
Sep 30 #Javascript
iview Upload组件多个文件上传的示例代码
Sep 30 #Javascript
VUE 配置vue-devtools调试工具及安装方法
Sep 30 #Javascript
angularJs中orderBy筛选以及filter过滤数据的方法
Sep 30 #Javascript
jQuery实现点击图标div循环放大缩小功能
Sep 30 #jQuery
angularJs使用ng-repeat遍历后选中某一个的方法
Sep 30 #Javascript
基于VUE实现的九宫格抽奖功能
Sep 30 #Javascript
You might like
火车采集器 免费版使出收费版本功能实现原理
2009/09/17 PHP
Smarty局部缓存的几种方法简介
2014/06/17 PHP
PHP可变函数学习小结
2015/11/29 PHP
php基于curl主动推送最新内容给百度收录的方法
2016/10/14 PHP
php+javascript实现的动态显示服务器运行程序进度条功能示例
2017/08/07 PHP
使用Apache的rewrite
2021/03/09 Servers
一句话JavaScript表单验证代码
2009/08/02 Javascript
基于jquery的loading 加载提示效果实现代码
2011/09/01 Javascript
jQuery源码分析-03构造jQuery对象-工具函数
2011/11/14 Javascript
js确定对象类型方法
2012/03/30 Javascript
Jquery实现图片放大镜效果的思路及代码(自写)
2013/10/18 Javascript
jQuery实现的Tab滑动选项卡及图片切换(多种效果)小结
2015/09/14 Javascript
JavaScript_object基础入门(必看篇)
2016/06/13 Javascript
jQuery ajax方法传递中文时出现中文乱码的解决方法
2016/07/25 Javascript
jQuery Ajax传值到Servlet出现乱码问题的解决方法
2016/10/09 Javascript
微信小程序 简单DEMO布局,逻辑,样式的练习
2016/11/30 Javascript
详解bootstrap的modal-remote两种加载方式【强化】
2017/01/27 Javascript
vue-cli随机生成port源码的方法
2019/09/02 Javascript
countUp.js实现数字滚动效果
2019/10/18 Javascript
node.js实现http服务器与浏览器之间的内容缓存操作示例
2020/02/11 Javascript
vue项目开启Gzip压缩和性能优化操作
2020/10/26 Javascript
Flask数据库迁移简单介绍
2017/10/24 Python
使用apidoc管理RESTful风格Flask项目接口文档方法
2018/02/07 Python
Python 解决中文写入Excel时抛异常的问题
2018/05/03 Python
python3 求约数的实例
2019/12/05 Python
使用Python爬虫库requests发送表单数据和JSON数据
2020/01/25 Python
Python datetime 如何处理时区信息
2020/09/02 Python
Scrapy基于scrapy_redis实现分布式爬虫部署的示例
2020/09/29 Python
Python性能测试工具Locust安装及使用
2020/12/01 Python
python爬取2021猫眼票房字体加密实例
2021/02/19 Python
餐厅经理岗位职责范本
2014/02/17 职场文书
暑期社会实践心得体会
2014/09/02 职场文书
用人单位聘用意向书
2015/05/11 职场文书
学历证明范文
2015/06/16 职场文书
新兵入伍决心书
2015/09/22 职场文书
2017大学生寒假社会实践心得体会
2016/01/14 职场文书