本文共 1756 字,大约阅读时间需要 5 分钟。
$anchorScroll
根据HTML5的规则,当调用这个函数时,它检查当前的url的hash值并且滚动到相应的元素。
监听$location.hash()并且滚动到url指定的锚点的地方。可以通过$anchorScrollProvider.disableAutoScrolling()禁用。
依赖:$window $location $rootScope
使用:$anchorScroll();
使用代码:
#id { height:500px;} #bottom { margin-top:1500px;}
跳到底部跳到顶部
(function () { angular.module("Demo", []) .controller("testCtrl",["$location", "$anchorScroll",testCtrl]); function testCtrl($location,$anchorScroll){ this.gotoTop = function () { $location.hash("top"); $anchorScroll(); }; this.gotoBottom = function () { $location.hash("bottom"); $anchorScroll(); }; }; }());
$controller
$controller负责实例化控制器。
这只是个简单的$injector调用,但为了以前版本的这个服务能被覆盖而被提取进一个服务。
依赖:$injector
使用:$controller(constructor,locals);
constructor:如果调用了一个函数,那么这个函数被认为是控制器构造函数。否则,它被认为是一个使用以下步骤检索控制器的构造函数的字符串:
1.检查控制器是否在$controllerProvider注册并命名。
2. 检查当前作用域上的字符串是否返回一个构造函数
3.在全局window对象上检查构造器。
locals:Object,将需要调用的控制器注册到当前控制器。
使用代码:
(function () { angular.module("Demo", []) .controller("demoCtrl",["$scope",demoCtrl]) .controller("testCtrl",["$controller","$scope",testCtrl]); function demoCtrl($scope){ $scope.print = function () { console.log("print"); }; this.prt = function () { $scope.print(); }; }; function testCtrl($controller,$scope){ var ctrl = $controller("demoCtrl",{$scope:$scope}); ctrl.prt(); // print }; }());
$document
一个jQuery或jqlite包装了的浏览器window.document对象。
依赖:$window
使用代码:
title-$document
这两天被$animate和$interpolate还有$http给折腾的心累啊,有一小部分代码还没测出来,所以先把这三个内容少点的整合到一篇文章先总结了先。明天看看花点时间把那三个给写完整吧,估计需要分三篇文章来记录$animate、$interpolate和$http呢。
转载地址:http://kgdzl.baihongyu.com/