AngularJS ng-model 指令
    ng-model 指令用于绑定应用程序数据到HTML 控制器(input,select,textarea)的值
ng-model指令
    ng-model指令可以将输入域的值与AngularJS 创建的变量绑定。
      实例:
        <div ng-app="myApp" ng-controller="myCtrl">
            名字:<input ng-model="name">
        </div>
        <script>
          var app = angular.module('mgApp',[]);
          app.controller('myCtrl',function($scope){
              $scope.name = "John Doe";
          })
      </script>

双向绑定
    双向绑定,在修改输入域的值时,AngularJS属性的值也将修改:
      实例:
        <div ng-app="myApp" ng-controller="myCtrl">
          名字:<input ng-model="name">
          <h1>你输入了:{{name}}</h1>
        </div>

验证用户输入
    实例:
      <form ng-app="" name="myForm">
        Email:
          <input type="email" name="myAddress" ng-model="text">
          <span ng-show="myForm.myAddress.$error.email">不是一个合法的邮箱地址</span>
      </form>
      以上实例中,提示信息会在ng-show 属性返回true的情况下显示

应用状态
    ng-model指令可以为应用数据提供状态值(invalid,dirty,touched,error)
      实例:
        <from ng-app="" name="myForm" ng-init="myText = 'test@runoob.com'">
            Email:
            <input type="email" name="myAddress" ng-model="myText" required>
            <h1>状态</h1>
            {{myForm.myAddress.$valid}}
            {{myForm.myAddress.$dirty}}
            {{myForm.myAddress.$touched}}
        </from>

CSS 类
    ng-model指令基于他们的状态为HTML 元素提供了CSS类:
      实例;
        <style>
            input .ng-invalid{
              background-color:lightblue;
            }
        </style>
        <body>
          <from ng-app="" name="myForm">
            输入你的名字:
            <input name="myAddress" ng-model="text" required>
          </from>
        </body>
        ng-model 指令根据表单域的状态添加/移除一下类
        ng-empty ng-not-empty ng-touched ng-untouched ng-valid ng-invalid
        ng-dirty ng-pending ng-pristine

AngularJS Scope(作用域)

        Scope(作用域) 是应用在HTML(视图)和JavaScript(控制器)之间的纽带。
        Scope是一个对象,有可能的方法和属性。
        Scope可应用在视图和控制器上。

如何使用Scope
      当你在AngularJS创建控制器时,你可以将$scope对象当做一个参数传递:
          实例: 控制器中的属性对应了视图上的属性:
            <div ng-app="myApp" ng-controller="myCtrl">
                <h1>{{carname}}</h1>
            </div>
            <script>
                var app = angular.module('myApp',[]);
                app.controller('myCtrl',function($scope){
                $scope.carname = "Volvo";
                })
            </script>
            当在控制器中添加$scope对象时,视图(HTML)可以获取了这些属性
            视图中,你不需要添加$scope前缀,只需要添加属性名即可,如{{carname}}。

Scope概述
    AngularJS应用组成如下:
    View(视图),即HTML。
    Model(模型),当前视图中可用的数据。
    Controller(控制器),即JavaScript 函数,可以添加或修改属性。
    scope 是模型。
    scope是一个JavaScript对象,带有属性和方法,这些属性和方法可以在视图和控制器中使用。
      实例: 如果你改变了视图,模型和控制器也会相应更新。
        <div ng-app="myApp" ng-controller = "myCtrl">
            <input ng-model="name">
              <h1>我的名字是{{name}}</h1>
        </div>
        <script>
          var app = angular.module('myApp',[]);
          app.controller('myCtrl',function($scope){
              $scope.name = "John Dow";
          })
        </script>

Scope 作用范围
    了解你当前使用的scope是非常重要的。
      实例:当我们使用ng-repeat 指令时,没个重复项都访问了当前的重复对象。
        <div ng-app="myApp" ng-controller="myCtrl">
          <ul>
            <li ng-repeat="x in name"></li>
          </ul>
        </div>
        <script>
            var app = angular.module('myApp',[]);
            app.controller('myCtrl',function($scope){
              $scope.names = ["Emil","Tobias","Linus"]
            });
        </script>
        每个<li>元素可以访问当前的重复对象,这里对应用的是一个字符串,并使用变量x 表示。

根作用域
    所有的应用都有一个$rootScope,它可以作用在ng-app 指令包含的所有HTML 元素中。
    $rootScope可作用域整个应用中,是各个controller中scope的桥梁。用rootscope定义的值,可以在各个controller中使用。
    实例:创建控制器时,将$rootScope作为参数传递,可在应用中使用:
      <div ng-app="myApp" ng-controller="myCtrl">
          <h1>{{lastname}} 家族成员:</h1>
          <ul>
              <li ng-repeat="x in name">{{x}}{{lastname}}</li>
          </ul>
      </div>
      <script>
          var app = angular.module('myApp',[]);
          app.controller('myCtrl',function($scope,$rootScope){
            $scope.names = ["Emil","Tobias","Linus"];
            $rootScope.lastname = "Refsnes";
          })
      </script>

    AngularJS 控制器
    AngularJs 控制器 控制AngularJS 应用程序的数据。
    AngularJS 控制器是常规的JavaScript对象。
AngularJS 控制器
      AngularJS 应用程序被控制器控制。
      ng-controller指令定义了应用程序控制器。
      控制器时JavaScript对象,由标准的JavaScript对象的构造函数 创建。
        实例:
          <div ng-app="myApp" ng-controller="myCtrl">
              名:<input type="text" ng-model = "firstName"><br>
              姓:<input type="text" ng-model = "lastName">
              姓名:{{firstName +""+lastName}}
          </div>
          <script>
            var app = angular.module('myApp',[]);
            app.controller('myCtrl',function($scope){
                $scope.firstName = "John";
                $scope.lastName = "Doe";
              })
          </script>
      应用解析:
          AngularJS 应用程序由ng-app定义。应用程序在<div>内运行。
          ng-controller = "myCtrl" 属性是一个Angular 指令。用于定义一个控制器。
          myCtrl 函数是一个JavaScript 函数。
          AngularJS 使用$scope对象来调用控制器。
          在AngularJS 使用$scope是一个应用像(属于应用变量和函数)
          控制器的$scope(相当于作用域,控制范围)用来保存AngularJS Mode(模型)的对象。
          控制器在作用域中创建两个属性(firstName 和lastName)。
          ng-model 指令绑定输入域到控制器的属性(firstName 和lastName)。

控制器方法
    上面的石磊演示了一个带有lastName 和firstName 这两个属性的控制器对象。
    控制器也可以有方法变量和函数
    实例
        <div ng-app="myApp" ng-controller="personCtrl">
          名:<input type="text" ng-model="firstName">
          姓:<input type="text" ng-model="lastName">
          姓名:{{fullName()}}
        </div>
        <script>
          var app = angular.module('myApp',[]);
          app.controller('personCtrl',function($scope){
              $scope.firsName = "John";
              $scope.lastName = "Doe";
              $scope.fullName = function(){
                return $scope.firstName + "" +$scope.lastName;
            }
          })
        </script>

外部文件中的控制器
    在大型的应用程序中,通常是把控制器存储在外部文件中。
    只需要把<script>标签中的代码复制到名为personController.js的外部文件中即可:
      实例:
          <div ng-app="myApp" ng-controller = "personCtrl">
              First Name:<input type="text" ng-model = "firstName">
              Last Name:<input type="text" ng-model="lastName">
              Full Name:{{firstName + " " +lastName}}
          </div>
          <script src="personController.js"></script>

其他实例
    实例:
      angular.module('myApp',[]).controller('namesCtrl',function($scope){
      $scope.names = [
          {name:'Jani',country:'Norway'},
          {name:'Hege',country:'Sweden'},
          {name:'Kai',country:'Denmark'}
        ];
      });
    <div ng-repeat="myApp" ng-controller="nameCtrl">
      <ul>
        <li ng-repeat="x in name">
          {{x.name +'x' +x.country]}}
        </li>
      </ul>
    </div>
    <script src="namesController.js"></script>

Angularjs基础(三)的更多相关文章

  1. AngularJS基础入门初探

    一.AngularJS简介 1.1 什么是AngularJS (1)一款非常优秀的前端JS框架,可以方便实现MVC/MVVM模式 (2)由Misko Hevery 等人创建,2009年被Google所 ...

  2. 现在就开始使用AngularJS的三个重要原因

    现在就开始使用AngularJS的三个重要原因 在线演示1 本地下载 如果你不熟悉什么是Angular.js的话,小编我强烈推荐你阅读 Javascript教程:AngularJS的五个超酷特性.简单 ...

  3. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

  4. Bootstrap <基础三十二>模态框(Modal)插件

    模态框(Modal)是覆盖在父窗体上的子窗体.通常,目的是显示来自一个单独的源的内容,可以在不离开父窗体的情况下有一些互动.子窗体可提供信息.交互等. 如果您想要单独引用该插件的功能,那么您需要引用  ...

  5. Bootstrap <基础三十一>插件概览

    在前面布局组件中所讨论到的组件仅仅是个开始.Bootstrap 自带 12 种 jQuery 插件,扩展了功能,可以给站点添加更多的互动.即使不是一名高级的 JavaScript 开发人员,也可以着手 ...

  6. Bootstrap <基础三十>Well

    Well 是一种会引起内容凹陷显示或插图效果的容器 <div>.为了创建 Well,只需要简单地把内容放在带有 class .well 的 <div> 中即可.下面的实例演示了 ...

  7. Bootstrap<基础三> 排版

    Bootstrap 使用 Helvetica Neue. Helvetica. Arial 和 sans-serif 作为其默认的字体栈. 使用 Bootstrap 的排版特性,您可以创建标题.段落. ...

  8. jdbc基础 (三) 大文本、二进制数据处理

    LOB (Large Objects)   分为:CLOB和BLOB,即大文本和大二进制数据 CLOB:用于存储大文本 BLOB:用于存储二进制数据,例如图像.声音.二进制文件 在mysql中,只有B ...

  9. AngularJS进阶(三十九)基于项目实战解析ng启动加载过程

    基于项目实战解析ng启动加载过程 前言 在AngularJS项目开发过程中,自己将遇到的问题进行了整理.回过头来总结一下angular的启动过程. 下面以实际项目为例进行简要讲解. 1.载入ng库 2 ...

随机推荐

  1. c# 文件名排序

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.C ...

  2. 动作方法中 参数,Json

    一.方法中可以出现的参数类 1.HttpServletRequest 2.HttpServletResponse 3.HttpSession 4.Model 二.返回接收json数据 1. 接收,返回 ...

  3. 07.使用FileStream类来实现对大文件的复制

    namespace _20.使用FileStream类来实现多媒体文件的复制 { class Program { static void Main(string[] args) { //需要被复制的文 ...

  4. POJ 3667 线段树区间合并

    http://www.cnblogs.com/scau20110726/archive/2013/05/07/3065418.html 用线段树,首先要定义好线段树的节点信息,一般看到一个问题,很难很 ...

  5. sublime开启vi编辑器功能,与vi常用快捷键

    sublime开启vi编辑器 install package -> vintageES 设置里面 ignored_packages 里面的vintage去掉 VI命令 游标控制 h 游标向左移 ...

  6. 重构指南 - 引入参数对象(Introduce Parameter Object)

    当一个方法的参数超过3个以上,就可以考虑将参数封装成一个对象.将参数封装成对象后提高了代码的可读性,并且该参数对象也可以供多个方法调用,以后如果增加删除参数,方法本身不需要修改,只需要修改参数对象就可 ...

  7. Python基础 数据类型 (字符串、列表、字典、元组、集合、堆、栈、树)

    数据类型有整型.布尔.字符串.列表.字典.元组.集合.堆.栈和树. 1.整型: 整型就是数字 数字表示 python2 64位机器,范围-2^63~2^63-1 超出上述范围,python自动转化为l ...

  8. JS的封装(JS插件的封装)

    JS中类的概念类,实际上就是一个function,同时也是这个类的构造方法,new创建该类的实例,new出的对象有属性有方法.方法也是一种特殊的对象. 类的方法在构造方法中初始化实例的方法(就是在构造 ...

  9. jQuery源码分析系列(版本1.9 - 1.10)

    jQuery是我们常用的javascript库,我们应该不仅要会用它还要知道它的工作原理. 1.jQuery结构及$方法的工作原理 2.对回调函数操作的Callbacks对象 3.promise规范的 ...

  10. Java开发中代码规范有哪些?

    Java开发中所要遵守的编码规范大体上有如下7点.命名规范.注释规范.缩进排版规范.文件名规范.声明规范.语句规范以及编程规范. 1.命名规范 (1)所有的标示符都只能用ASCⅡ字母(A-Z或a-z) ...