对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 相关文章推荐
jQuery Uploadify 上传插件出现Http Error 302 错误的解决办法
Dec 12 Javascript
实例讲解JS中setTimeout()的用法
Jan 28 Javascript
微信jssdk用法汇总
Jul 16 Javascript
ThinkPHP+jquery实现“加载更多”功能代码
Mar 11 Javascript
JavaScript实现类似淘宝的购物车效果
Mar 16 Javascript
JS查找英文文章中出现频率最高的单词
Mar 20 Javascript
JS计算输出100元钱买100只鸡问题的解决方法
Jan 04 Javascript
详解vue中axios的封装
Jul 18 Javascript
微信JS-SDK updateAppMessageShareData安卓不能自定义分享详解
Mar 29 Javascript
vue响应式更新机制及不使用框架实现简单的数据双向绑定问题
Jun 27 Javascript
vue-cli随机生成port源码的方法
Sep 02 Javascript
vue实现列表滚动的过渡动画
Jun 29 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
Php Image Resize图片大小调整的函数代码
2011/01/17 PHP
php集成动态口令认证
2016/07/21 PHP
Yii2 hasOne(), hasMany() 实现三表关联的方法(两种)
2017/02/15 PHP
解决laravel上传图片之后,目录有图片,但是访问不到(404)的问题
2019/10/14 PHP
PHP7新特性
2021/03/09 PHP
jquery imgareaselect 使用利用js与程序结合实现图片剪切
2009/07/30 Javascript
jQuery学习笔记之jQuery的动画
2010/12/22 Javascript
javascript测试题练习代码
2012/10/10 Javascript
JQuery入门—编写一个简单的JQuery应用案例
2013/01/03 Javascript
js中 关于undefined和null的区别介绍
2013/04/16 Javascript
jQuery层级选择器用法分析
2015/02/10 Javascript
jQuery实现文件上传进度条特效
2015/08/12 Javascript
深入理解JavaScript中的浮点数
2016/05/18 Javascript
jQuery中借助deferred来请求及判断AJAX加载的实例讲解
2016/05/24 Javascript
JS实现的表格行上下移动操作示例
2016/08/03 Javascript
浅谈js中StringBuffer类的实现方法及使用
2016/09/02 Javascript
angularjs 中$apply,$digest,$watch详解
2016/10/13 Javascript
Vue自定义事件(详解)
2017/08/19 Javascript
webpack 样式加载的实现原理
2018/06/12 Javascript
django js 实现表格动态标序号的实例代码
2019/07/12 Javascript
Layui Table js 模拟选中checkbox的例子
2019/09/03 Javascript
解决layui表格的表头不滚动的问题
2019/09/04 Javascript
Vue3.0数据响应式原理详解
2019/10/09 Javascript
用Python写冒泡排序代码
2016/04/12 Python
Python模拟三级菜单效果
2017/09/11 Python
TensorFlow中权重的随机初始化的方法
2018/02/11 Python
使用python画个小猪佩奇的示例代码
2018/06/06 Python
Python拆分大型CSV文件代码实例
2019/10/07 Python
Python绘制组合图的示例
2020/09/18 Python
Selenium Webdriver元素定位的八种常用方式(小结)
2021/01/13 Python
2014年学校后勤工作总结
2014/12/06 职场文书
javascript数组includes、reduce的基本使用
2021/07/02 Javascript
python非标准时间的转换
2021/07/25 Python
Java后台生成图片的完整步骤
2021/08/04 Java/Android
MySQL中连接查询和子查询的问题
2021/09/04 MySQL
请求模块urllib之PYTHON爬虫的基本使用
2022/04/08 Python