代码改变世界

学习angular.js的一些笔记想法(上)

2016-10-19 15:55  改吧  阅读(594)  评论(0编辑  收藏  举报

1.data-ng-app与ng-app的区别

  data-ng-app是为了h5不报错

 2.ng-class

  不多说就来拿例子说吧

  html代码

<div class='color-changer' data-ng-class="{'color-changer-hiden':!colorChanger}">
</div>

  js代码:

$scope.colorChanger=false;

  此时的变量colorChanger=false,那么!colorChanger=true,所以:‘color-changer-hiden':true;这时的div就addClass这个color- changer-hiden,当‘color-changer-hiden':false是removeClass这个color- changer-hiden累;

  再比如说

  

  $scope.lala = true;
<div ng-class="{‘selectClass‘:select,‘choiceClass‘:choice,‘haha‘:lala}"></div>

  因为lala=true,所以div的class='haha';

哈哈 你懂了吗?反正我懂了哈

 3.$rootScope:

  首先,$scope是连接html跟javascript的纽带

  我们都知道angular.js有个$scope,哈哈,那么$rootScope的意思呢,$rootScope可作用于整个应用中,是各个controller中scope的桥梁。用于rootscope定义的值,可以在各个controller中应用,$rootScope是所有$scope的最上层
  $rootscope可以作用于整个应用中,是各个controller中scope的桥梁,是贯穿各个controller的

4.数据绑定

  angular的数据绑定是{{}}双大括号,

  html代码:

<link rel="stylesheet" type="text/css" data-ng-href="{{colors}}" href='/'>

  js代码:

$rootScope.colors='static/css/blue.css'

就给页面上的这个colors赋值了。

 5.ng-transclude

  (1)ng-transclude指明的是一个插入的位置,

  (2)指令中标签里的元素先删除然后被嵌入所包含的内容所替代

  好的上代码

  

html代码
<div ng-controller="Ctrl">
      <input ng-model="title"><br>
      <textarea ng-model="text"></textarea> <br/>
      <pane title="{{title}}">{{text}}</pane>
</div>

js代码
app.directive('pane', function(){
    return {
      restrict: 'E',
      transclude: true,
      scope: { title:'@' },
      template: '<div style="border: 1px solid black;">' +
                  '<div style="background-color: gray">                        {{title}}</div>' +
                  '<div ng-transclude></div>' +
                '</div>'
    };
});

最后的效果

<div style="border: 1px solid black;">
    <div style="background-color: gray">我是标题</div>
    我是内容
</div>

  这样看应该理解的差不多了哈

 6.path

path在我用到的时候的功能差不多相当于a标签的href属性

7.restrict:以my-menu为例

字母           声明风格          实例
E 元素 <my-menu></my-menu>
A 属性 <div my-menu='product'></div>         
C 样式表 <div class='my-menu'></div>
M 注释 <!-- directive:my-menu -->

 

                  E:element;A:attribute;C:class;M:注释的单词是啥啊,不知道为什么是M

8.directive:指令机制,上代码

<html ng-app='app'>
    <body>
        <hello></hello>
    </body>

    <script src="../angular-1.0.3/angular.min.js"></script>
    <script src="HelloDirect.js"></script>
</html>
var appModule = angular.module('app', []);
appModule.directive('hello', function() {
    return {
        restrict: 'E',
        template: '<div>Hi there</div>',
        replace: true
    };
});

结合7来看,就知道这个directive的指令是声明元素

9.transclude:上代码

<html ng-app='app'>
    <head>
        <meta http-equiv="content-type" content="text/html; charset=utf-8" />
    </head>
    <body>
        <hello>
            <br/>
            <span>原始的内容,</span><br/>
            <span>还会在这里。</span>
        </hello>
        <hello>
        </hello>
    </body>

    <script src="../angular-1.0.3/angular.min.js"></script>
    <script src="Transclude.js"></script>
</html>
var appModule = angular.module('app', []);
    appModule.directive('hello', function() {
    return {
        restrict: 'E',
        template: '<div>Hi there <span ng-transclude></span></div>',
        transclude: true
    };
});

实现的效果为

Hi there
原始的内容,
还会在这里。
Hi there

总结就是:transclude: true,js代码里面的template会在<hello>内部出现是<hello></hello>的子标签。

 10.当<div class='hello-js'></div>

js代码需要以下写法:

app.directive('helloJs', function() {
  return {
  restrict:'C', template:
'Name: {{customer.name}} Address: {{customer.address}}' }; });

就是class里面的-线不要,js的写法是驼峰式,template是随便写的哈。

 11.$location.hash():得到或者设置url里的锚点部分

 URL http://example.com/#/some/path?foo=bar&baz=xoxo#hashValue
var hash = $location.hash();
// => "hashValue"


 $location.hash([id]):这条语句是快速定位页面为[id]的元素

12.

angular.module('anchorScrollExample', [])

.controller('ScrollController', ['$scope', '$location', '$anchorScroll',
  function ($scope, $location, $anchorScroll) {

    $scope.gotoBottom = function() {

      // 将location.hash的值设置为
      // 你想要滚动到的元素的id
      $location.hash('bottom');

      // 调用 $anchorScroll()
      $anchorScroll();

    };
  }]);

页面滚动到id='bottom'的位置。$anchorScroll();

 13.angular.element(element):angular获得页面元素,上代码

var leftSide=angular.element(document.querySelector('.left-side'));

这个代码就是把class='left-side'的dom元素拿出来咯

 14.

app.config(['$locationProvider',function($locationProvider){
        $locationProvider.html5Mode(true);
    }]);

这段代码我一开始不知道什么意思,然后就去问问小伙伴,然后就得到了很好的解决,我就不多解释了,一个链接就能解决的问题啦,上链接http://www.cnblogs.com/wolf-sun/p/4656216.html

14:ng-include用于包含外部的文件

<div ng-include="'myFile.htm'"></div>

就是这个div里面是用于展示myFile.html的这个文件内容

 15.当html上有{{person}},然后js是$scope.person.name='wenwen'

那么页面上得到的效果就是:{'name':'wenwen'}一个json对象,哈哈

16.$watch:是一个scope函数,用于监听模型变化,当你的模型部分变化时它会通知你

$watch(watchExpression, listener, objectEquality);

每个参数的说明如下:

watchExpression:监听的对象,它可以是一个angular表达式如'name',或函数如function(){return $scope.name}。

listener:当watchExpression变化时会被调用的函数或者表达式,它接收3个参数:newValue(新值), oldValue(旧值), scope(作用域的引用)

objectEquality:是否深度监听,如果设置为true,它告诉Angular检查所监控的对象中每一个属性的变化. 如果你希望监控数组的个别元素或者对象的属性而不是一个普通的值, 那么你应该使用它

上代码

<!DOCTYPE html>
<html ng-app='myApp'>
<head>
    <meta charset='UTF-8'>
    <title>表达式</title>
    <script type="text/javascript" src='static/plugins/angular.min.js'></script>
</head>
<body>
    <div ng-controller='mycontroller'>
        <input ng-model='expr' type='text' placeholder='enter an expression'/>
        <div>{{parseExpr}}</div>
    </div>
</body>
<script type="text/javascript">
    var app=angular.module('myApp',[]);
    app.controller('mycontroller',['$scope','$parse',function($scope,$parse){
        $scope.person={
            name:'wenen'
        };
        $scope.$watch('expr',function(newVal,oldVal,scope){
            if(newVal != oldVal){
                var parseFun=$parse(newVal);
                scope.parseExpr=parseFun(scope);
            }
        })
    }])
</script>
</html>

用了$watch监听input:ng-model='expr'的变化,然后parseExpr随着变化呗

17.数据绑定

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="">
  <p>名字 : <input type="text" ng-model="name"></p>
  <h1>Hello {{name | uppercase}}</h1>
</div>

</body>
</html>
名字 : sssss

Hello SSSSS

 18.过滤器,简单的页面上的过滤器

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="">
  <p>名字 : <input type="text" ng-model="name"></p>
  <h1>Hello {{name | uppercase}}</h1>
    <input type='number' ng-model='numbers'>
    <h1>{{numbers | number:2}}</h1>
    <input type='number' ng-model='n1'>
    <h1>{{n1 | currency}}</h1>
</div>

</body>
</html>

效果为:

再稍微复杂一点的就是要用到js的啦,首先来说一下orderBy:字面意思就是排序呗,上代码

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="myApp" ng-controller="namesCtrl">

<p>循环对象:</p>
<ul>
  <li ng-repeat="x in names | orderBy:'country'">
    {{ x.name + ', ' + x.country }}
  </li>
</ul>

</div>


<script>
	var app=angular.module('myApp',[]);
	app.controller('namesCtrl',function($scope){
		$scope.names=[
			{"name":"wenwen","country":"china"},
			{"name":"hello","country":"aweden"},
			{"name":"world","country":"denmark"}
		]
	})
	</script>
</body>
</html>

 效果就是:

循环对象:

hello, aweden
wenwen, china
world, denmark

看到没,是按country的首字母排序的,是的,就是这样过滤

现在再深入一点就是搜索啦,也是还可以啦,上代码

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="myApp" ng-controller="namesCtrl">

<p>输入过滤:</p>

<p><input type="text" ng-model="test"></p>

<ul>
  <li ng-repeat="x in names | filter:test | orderBy:'country'">
    {{ (x.name | uppercase) + ', ' + x.country }}
  </li>
</ul>

</div>

<script>
	var app=angular.module('myApp',[]);
	app.controller('namesCtrl',function($scope){
		$scope.names=[
			{"name":"wenwen","country":"china"},
			{"name":"hello","country":"aweden"},
			{"name":"world","country":"denmark"}
		]
	})
	</script>

</body>
</html>

 效果为

 

一个简单的搜索框就出来了,不得不说很强大啊,加了filter|test咯,这个test就是绑定了输入框啦,so~~~你懂的😉

 filter这个过滤器可以从给定数组中选择一个符合条件的子集,并生成一个新数组返回。

filter也可以加对象咯,就成了对象过滤器啦,上代码

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="myApp" ng-controller="namesCtrl">

<p>输入过滤:</p>

<p><input type="text" ng-model="test"></p>

	<p ng-model='hello'></p>
	<h1>{{hello | filter:{'name':'Ari'} }}</h1>
</div>


</body>
	<script>
		var app=angular.module('myApp',[]);
	app.controller('namesCtrl',function($scope){
		$scope.hello=[{
			'name': 'Ari',
			'City': 'San Francisco',
			'favorite food': 'Pizza'
			},{
			'name': 'Nate',
			'City': 'San Francisco',
			'favorite food': 'indian food'
			}]
	})
	</script>
</html>

 结果呢

[{"name":"Ari","City":"San Francisco","favorite food":"Pizza"}]

 返回了这个对象。是的

 阿哈 还有一种是自定义过滤器,然后就上代码吧

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://cdn.static.runoob.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="myApp" ng-controller="personCtrl">
<input type='text' ng-model='lastname'/>
<p>姓名为 {{ lastname | capitalize}}</p>

</div>

<script type="text/javascript">
	var app=angular.module('myApp', []);
	app.controller('personCtrl',['$scope',function($scope){
		$scope.lastname='wenwen';
	}]);
	app.filter('capitalize', function() {
	return function(input) {
		if (input) {
			return input[0].toUpperCase() + input.slice(1);
		}
	}
	});
</script>

</body>
</html>

 效果呢:

就是这样啦。slice[start,end)我相信你们都知道啦,从start索引开始咯包括哈,看到我用了[没有呀,哈哈 到end索引我用了)这个就是不包括拉。索引是从0开始啦,我比较笨就提醒自己啦

恩,这个写的有点太多了 还是接下来的笔记再重新开一篇随笔吧