zoukankan      html  css  js  c++  java
  • [AngularJS] AngularJS系列(1) 基础篇

    目录

    一年前开始使用AngularJS(以后简称ng),如今ng已经出2了.虽说2已完全变样,但是1.x还是足够优秀。

    什么是AngularJS?

    ng是一个js框架,目前最新版本为1.5.8.

    官网:https://angularjs.org/

    下载:

    Install-Package AngularJS.Core

    npm install angular@1.5.8

    为什么使用/ng特性

    ng是非常少有的双向绑定框架。

    特性:

    1. MV*
    2. 模块化开发
    3. 双向绑定
    4. 指令系统

    Hello World

    构建1个ng页面 非常容易

    <!DOCTYPE html>
    <html ng-app>
    <head>
        <title>AngularJS</title>
        <script src="//cdn.bootcss.com/angular.js/1.5.8/angular.min.js"></script>
    </head>
    <body>
        <h1>{{model}}</h1>
        <input type="text" ng-model="model">
    </body>
    
    </html>
    

    这几乎是ng最简单的hello world 页面

    其中

    ng-app ng内置指令,标记ng管理的区域

    {{model}} 则为ng的双括号插值语法,此处输出模型model的值

    ng-model ng内置指令,用来绑定具体模型

    内置指令

    在ng中:在HTML中ng-xxx的为指令

    ng中包含:

    • ng-app

      • 指定ng管理区域
    • ng-init

      • 初始化
    • ng-model

      • 双向数据绑定指令
    • ng-bind

      • 绑定数据(默认会对HTML数据转义)
    • ng-cloak

      • 加载前隐藏,加载完显示(ng模块加载完会移出特性)
    • ng-repeat

      • 循环遍历(每个元素作用域上有$id $index $first $last $middle $even $odd属性与item并齐)
      • (key,value) in data track by $index
    • ng-class

      • ng-class="{red:true}" 根据对象设置class
    • ng-show / ng-hide / ng-if

      • 是否显示 / 隐藏 / 存在 (ng-if通过注释标记能还原)
    • ng-src / ng-href

      • 防止默认请求的表达式错误
    • ng-switch

      • 当大量判断逻辑的时候,减少ng-show等的使用
    • ng-checked / ng-selected / ng-readonly / ng-disabled

      • 一般可用ng-model(以上4个指令不是双向绑定,可实现全选勾选框代码)
    • ng-change / ng-copy / ng-click / ng-dblclick / ng-focus / ng-blur / ng-submit

      • ng常用事件指令

    内置过滤器

    为了对数据做一些常用的操作,ng定义了一些内置的过滤器

    <!DOCTYPE html>
    <html ng-app>
    <head>
        <title>AngularJS</title>
        <script src="//cdn.bootcss.com/angular.js/1.5.8/angular.min.js"></script>
    </head>
    <body ng-init="model=10">
        <h1>{{model | currency}}</h1>
        <input type="text" ng-model="model">
    </body>
    </html>
    

    ng-init 初始化模型数据

    {{model | currency}} 的currency则为货币过滤器 

    1. currency (货币处理)

      {{num | currency : '¥'}}

    2. date (日期格式化,参考代码中的DATE_FORMATS)

      {{date | date : 'yyyy-MM-dd hh:mm:ss EEEE'}}

    3. filter(匹配子串)

      {{ childrenArray | filter : {name : 'i'} }} //匹配name属性中含有i的

    4. json(格式化json对象)

      {{ jsonTest | json}}

    5. limitTo(限制数组长度或字符串长度)

      {{ childrenArray | limitTo : 2 }} //将会显示数组中的前两项

    6. lowercase(小写)
    7. uppercase(大写)
    8. number(格式化数字)
    9. orderBy(排序)

    模块化开发

    在实际开发环境中,不会像上述例子中 一行js代码都不写.

    在ng中,我们的代码一般在某个模块下进行开发的.

    方式一:

    <!DOCTYPE html>
    <html ng-app="myApp">
    <head>
        <title>AngularJS</title>
        <script src="Scripts/angular.min.js"></script>
    </head>
    <body ng-controller="HelloCtrl">
        <h1>{{model}}</h1>
        <input type="text" ng-model="model">
        <script>
            var app = angular.module('myApp', []);
            app.controller('HelloCtrl', ['$scope', function ($scope) {
                $scope.model = 'Hello World';
            }]);
        </script>
    </body>
    </html>
    

    方式二(也可同时创建多个页面模块):

    <!DOCTYPE html>
    <html>
    <head>
        <title>AngularJS</title>
        <script src="Scripts/angular.min.js"></script>
    </head>
    <body ng-controller="HelloCtrl">
        <h1>{{model}}</h1>
        <input type="text" ng-model="model">
        <button type="button" ng-click="test()">Test</button>
    <script>
        var app = angular.module('myApp', []);
        app.controller('HelloCtrl', ['$scope', function ($scope) {
            $scope.model = 'Hello World';
        }]);
        angular.bootstrap(document, ['myApp']);//使用模块初始化页面
    </script>
    </body>
    </html>

    简单解释上面的API

    • angular.bootstrap()

      • angular.bootstrap(dom,['myApp']) 手动加载模块myApp
    • angular.module()

      • angular.module('myApp',[],cfgFn) //创建模块
      • angular.module('myApp) //获取模块
    • module.run()

      • module.run(function(){}) //相当于程序的Main方法
    • module.controller()

      • module.controller('HomeCtrl',function(){})//创建控制器
      • module.controller('HomeCtrl',['$scope',function(scope){}])//创建控制器(推荐)

    在ng中建议将业务逻辑放在controller中执行。

    本文地址:http://www.cnblogs.com/neverc/p/5903257.html

  • 相关阅读:
    C# HTTP系列9 GET与POST示例
    [译]Android Studio 3.6 新特性概览
    mysql error 1290 hy000:The MySQL server is running with the --skip-grant-tables option so it cannot execute this statemen' 解决方案
    mysql error 1130 hy000:Host 'localhost' is not allowed to connect to this mysql server 解决方案
    Windows+Apache2.4.10+PHP7.0+MySQL5.6.21安装
    php版本的选择
    PHP,Mysql根据经纬度计算距离并排序
    windows无法启动MySQL服务 错误1067
    PHP MYSQL 搜索周边坐标,并计算两个点之间的距离
    html5获取用户当前的地理位置,即经纬度。
  • 原文地址:https://www.cnblogs.com/neverc/p/5903257.html
Copyright © 2011-2022 走看看