• AngularJS 简介


    AngularJS 历史

    AngularJS 是比较新的技术,版本 1.0 是在 2012 年发布的。

    AngularJS 是由 Google 的员工 Miško Hevery 从 2009 年开始着手开发。

    这是一个非常好的构想,该项目目前已由 Google 正式支持,有一个全职的开发团队继续开发和维护这个库。

    AngularJS 简介

    AngularJS 是一个 JavaScript 框架。它可通过 <script> 标签添加到 HTML 页面。

    AngularJS 通过 指令 扩展了 HTML,且通过 表达式 绑定数据到 HTML。

    AngularJS 是一个 JavaScript 框架

    AngularJS 是一个 JavaScript 框架。它是一个以 JavaScript 编写的库。

    AngularJS 是以一个 JavaScript 文件形式发布的,可通过 script 标签添加到网页中:

    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>

    AngularJS 扩展了 HTML

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.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}}</h1>
    </div>
    
    </body>
    </html>

    实例讲解:

    当网页加载完毕,AngularJS 自动开启。

    ng-app 指令告诉 AngularJS,<div> 元素是 AngularJS 应用程序 的"所有者"。

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

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

    如果您移除了 ng-app 指令,HTML 将直接把表达式显示出来,不会去计算表达式的结果。

    什么是 AngularJS?

    AngularJS 使得开发现代的单一页面应用程序(SPAs:Single Page Applications)变得更加容易。

    • AngularJS 把应用程序数据绑定到 HTML 元素。
    • AngularJS 可以克隆和重复 HTML 元素。
    • AngularJS 可以隐藏和显示 HTML 元素。
    • AngularJS 可以在 HTML 元素"背后"添加代码。
    • AngularJS 支持输入验证。

    AngularJS 指令

    正如您所看到的,AngularJS 指令是以 ng 作为前缀的 HTML 属性。

    ng-init 指令初始化 AngularJS 应用程序变量。

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <script src="angular.js" type="text/javascript"></script>
    </head>
    <body>
        <div ng-app="" ng-init="firstname='John'">
            <p>
                姓名为:<span ng-bind="firstname"></span></p>
        </div>
    </body>
    </html>

    HTML5 允许扩展的(自制的)属性,以 data- 开头。
    AngularJS 属性以 ng- 开头,但是您可以使用 data-ng- 来让网页对 HTML5 有效。

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> 
    </head>
    <body>
    
    <div data-ng-app="" data-ng-init="firstName='John'">
    
    <p>姓名为 <span data-ng-bind="firstName"></span></p>
    
    </div>
    </body>
    </html>

    AngularJS 表达式

    AngularJS 表达式写在双大括号内:{{ expression }}

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

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

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

    实例 {{ 5 + 5 }} 或 {{ firstName + " " + lastName }}

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> 
    </head>
    <body>
    
    <div ng-app="">
      <p>我的第一个表达式: {{ 5 + 5 }}</p>
    </div>
    
    </body>
    </html>

    AngularJS 应用

    AngularJS 模块(Module) 定义了 AngularJS 应用。

    AngularJS 控制器(Controller) 用于控制 AngularJS 应用。

    ng-app指令定义了应用, ng-controller 定义了控制器。

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> 
    </head>
    <body>
    
    <p>尝试修改以下表单。</p>
    
    <div ng-app="myApp" ng-controller="myCtrl">//此处ng-app属性不等于空
    
    名: <input type="text" ng-model="firstName"><br>
    姓: <input type="text" ng-model="lastName"><br>
    <br>
    姓名: {{firstName + " " + lastName}}
    
    </div>
    
    <script>
    var app = angular.module('myApp', []);//AngularJS 模块
    app.controller('myCtrl', function($scope) {//AngularJS 控制器
        $scope.firstName= "John";
        $scope.lastName= "Doe";
    });
    </script>
    
    </body>
    </html>

    AngularJS 初始化加载流程

    1、浏览器载入HTML,然后把它解析成DOM。
    2、浏览器载入angular.js脚本。
    3、AngularJS等到DOMContentLoaded事件触发。
    4、AngularJS寻找ng-app指令,这个指令指示了应用的边界。
    5、使用ng-app中指定的模块来配置注入器($injector)。
    6、注入器($injector)是用来创建“编译服务($compile service)”和“根作用域($rootScope)”的。
    7、编译服务($compile service)是用来编译DOM并把它链接到根作用域($rootScope)的。
    8、ng-init指令将“World”赋给作用域里的name这个变量。
    9、通过{{name}}的替换,整个表达式变成了“Hello World”。

  • 相关阅读:
    hdu 4009 Transfer water(最小型树图)
    如何使用java调用DLL运行C++(初篇)
    腾讯笔试题(2015)
    md5算法原理一窥(其一)
    hdu 3038 How Many Answers Are Wrong ( 带 权 并 查 集 )
    Java 基础知识点(必知必会其二)
    Java 基础知识点(必知必会其一)
    web基础之hibernate(一篇)
    web基础之Structs(一篇)
    mysql知识初篇(一)
  • 原文地址:https://www.cnblogs.com/chrisghb8812/p/5631047.html
Copyright © 2020-2023  润新知