Angular学习笔记(One Day)

490 阅读3分钟

Angular基础学习

Angular基础指令

  • ng-app:指令定义一个AngularJS应用程序。
  • ng-model 指令把元素值(比如输入域的值)绑定到应用程序 (v-model)。
  • ng-bind 指令把应用程序数据绑定到 HTML 视图 (v-bind)。
  • ng-init 指令初始化Angular JS医用程序变量
  • .directive 创建自定义指令

看一个双向绑定的小例子。

//双向绑定
<div ng-app="">
  <p ng-init = "firstName= 'coolFish'">名字 : <input type="text" ng-model="name"></p>
  <h1>Hello {{firstName}}{{name}}</h1>
  <p ng-bind="name"></p>
</div>
//循环
<div ng-app="" ng-init="names=['Jani','Hege','Kai']">
  <p>使用 ng-repeat 来循环数组</p>
  <ul>
    <li ng-repeat="x in names">
      {{ x }}
    </li>
  </ul>
</div>
//循环对象数组
<div ng-app="" ng-init="names=[
{name:'coolFish',country:'厦门'},
{name:'亦总',country:'广州'},
{name:'体育老师',country:'上海'}]">
<p>循环对象:</p>
<ul>
  <li ng-repeat="x in names">
  {{ x.name + ', ' + x.country }}</li>
</ul>
</div>
//自定义指令
<body ng-app="myApp">
<runoob-directive></runoob-directive>
<script>
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        template : "<h1>coolFish!</h1>"
    };
});
</script>
</body>

小结:用过vue的看这个应该会很好理解。当网页加载完毕,AngularJS 自动开启。

ng-app 指令告诉 AngularJS,

元素是 AngularJS 应用程序 的"所有者"。

ng-model 指令把输入域的值绑定到应用程序变量 name

ng-bind 指令把应用程序变量 name 绑定到某个段落的 innerHTML。

ng-init 直接在文本中定义并且初始化变量。然后立马就能使用。

自定义指令 可以通过以下4中方式调用,并且可以限制使用,通过特定方式调用

//元素名
<runoob-directive></runoob-directive>
//属性
<div runoob-directive></div>
//类名
<div class="runoob-directive"></div>
//注释
<!-- directive: runoob-directive -->
//限制调用
var app = angular.module("myApp", []);
app.directive("runoobDirective", function() {
    return {
        restrict : "A",
        template : "<h1>自定义指令!</h1>"
    };
});

小结:restrict的值可以是以下几种, 默认值为 EA, 即可以通过元素名和属性名来调用指令

  • E 作为元素名使用
  • A 作为属性使用
  • C 作为类名使用
  • M 作为注释使用

Angular表达式

  • AngularJS 表达式写在双大括号内:**{{ expression }}**和Vue中的差值表达式有点像,但是强大的多

  • AngularJS 表达式把数据绑定到 HTML,这与 ng-bind 指令有异曲同工之妙。

  • AngularJS 将在表达式书写的位置"输出"数据。

  • AngularJS 表达式:它们可以包含文字、运算符和变量。

<div ng-init = "firstName= 'coolFish'"  ng-app="">
  <p>我的第一个表达式: {{ 5 + 1 +firstName}}</p>//结果显示我的第一个表达式:6coolFish
</div>
//初始化并且运算
<div ng-app="" ng-init="quantity=1;cost=5">
 <p>总价: <span ng-bind="quantity * cost"></span></p>  //5
 </div>
//字符串和数字
<div ng-app="" ng-init="name='coolFish';age=10">
	<p>{{ '姓名:'+name+" "+'年龄:' + age }}</p> 
 </div>
//对象
<div ng-app="" ng-init="person={firstName:'cool',lastName:'Fish'}">
 <p>姓为 {{ person.lastName }}</p>
 </div>
//数组
<div ng-app="" ng-init="points=[1,15,19,2,40]">
 <p>第三个值为 {{ points[2] }}</p>
 </div>

小结:用到这里,一个感觉,真他吗溜,但是文档说,Angular表达式不支持条件判断,循环及其异常,但是能支持过滤器,这里指的是在这个差值表达式内

Angular应用

名: <input type="text" ng-model="firstName"><br>
	<div ng-app="myApp" ng-controller="myCtrl">
        姓: <input type="text" ng-model="lastName"><br>
<br>
姓名: {{firstName + " " + lastName}}</div>
</div>
<script>
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
    $scope.firstName= "John";
    $scope.lastName= "Doe";
});

小结:这里model定义了应用范围,Controller用于控制应用,