AngularJS基础语法(2009版本)

jquery和AngularJS 数据绑定和获取对比:

jquery,要操作DOM:

 angularJS,无需操作DOM就可以进行动态数据变化:

 要使用Angularjs就需要在html页面先引入:

ng-app: 

html页面中,需要给标签绑定ng-app指令标记当前页面,注意ng-app通常绑定给body标签。

如果ng-app="" ,可以默认写为ng-app

只有给html绑定了ng-app,才会产生$rootScope。

如果不给页面body绑定ng-app指令,那么在view视图中{{}}就无法生效,页面直接显示为{{}}字符。

ng-model:

 

 语句和表达式的区别:

ng-init:

用来初始化当前作用域变量

ng-init是单向数据绑定,由页面view->模型model;

ng-model是双向数据绑定,页面view->模型model ,也可以从模型model->页面view

双向数据绑定:

 作用域对象和控制器对象:

给html绑定ng-app指令,会生成最顶层的$rootScope作用域对象。

给单独的标签添加ng-controller绑定一个函数,ng-controller指令会自动new此函数。这个函数会接收一个形参必须是$scope,在这个函数中就可以对ng-controller定义区域内的变量进行变量初始化和创建方法,产生一个单独的作用域空间。注意必须使用$scope初始化变量和创建方法。

 

所以控制器函数的形参一定是$scope。

 总结:

ng-app会创建一个根作用域对象$rootScope,通过ng-init初始化全局变量。

ng-controller会创建控制器对象例如MyController,生成一个单独的作用域空间$scope,$scope是在$rootScope下的,在ng-controller控制的view视图内,可以直接调用ng-init初始化的变量。

例如:在$rootScope全局作用域下初始化age变量:

 在控制器对象MyController区域view视图内直接调用age

 

 

 ng-app和ng-controller也可以写在一个标签上

依赖注入: 

依赖注入分为声明式依赖注入和命令式依赖注入,首先理解一下声明式和命令式的区别:

 

声明式依赖注入: 

 event就是依赖,同理控制器中的$scope也是依赖;

这种以形参的形式被注入使用的方式就是声明式依赖注入

命令式依赖注入:

AngularJS的模块对象

在angular中,像下面这种生成MyController生成控制器对象这种方式不多,更多的是使用Angular的模块对象angular.module.controller()更方便。 

angular.module模块可在全局位置创建、注册、获取Angular模块。所有模块(angular核心或第三方)都必须使用这个机制注册才能在应用中生效。

一个模块式服务、指令、控制器、过滤器和配置信息的集合。angular.module用于配置injector。

首先想使用angular,就需要先引入:

书写视图:

JS:

视图中的ng-app绑定的名称就是模块的名字

 生成作用域对象代码优化:

链式调用:

再次优化:

注意:

表达式:

常用指令:

ng-repeat:

ng-repeat的$index输出数组的下标;

ng-repeat的$first输出当前元素是否是第一项,输出布尔值;

ng-repeat的$last输出当前元素是否是最后一项,输出布尔值;

ng-repeat的$middle输出当前元素是否属于中间项,输出布尔值;

ng-repeat的$odd输出当前元素下标是否属于奇数,输出布尔值;

ng-repeat的$even输出当前元素下标是否属于偶数,输出布尔值;

遍历数组显示数据,数组有几个元素就会产生几个新的作用域,见下图验证: 

 

ng-bind:

ng-show、ng-hide:

ng-style:

ng-mouseenter、ng-mouseleave:

ng-class:

需求:循环ul标签,各行变色 

AngularJS内置服务  $http:

遍历动态生成表格:

 

 angular的过滤器filter

参考:AngularJS 过滤器 (详解)_angularjs过滤器-CSDN博客

过滤器作用:将数据转换成自己想要的形式后输出,格式化数据;

过滤器写法:待处理数据 | 过滤器名称:参数

angular内置过滤器:

currency :"货币"

例如:

 

date : "日期格式字符串"

例如: 

 

 tip: 过滤器可以链式调用

 

 uppercase

将字符串text大写输出

filter

filter第一个参数可以是下列三种类型,第二个参数为true的时候顺序反转。

等等......

详细可以看上面的参考链接,博主很详细。

自定义过滤器:

如果内置的过滤器无法满足自己的需求,就可以自定义过滤器。

需求:将手机号码中间4位用型号表示:

js:

自定义过滤器写法:

angular.moudule('ng-app绑定的名称',[]).filter("过滤器名称",回调(return回调))

 view:

优化:

无论号码多长,只保留前三位和后四位,中间使用*隐藏

angularJS的指令:

AngularJS 参考手册 | 菜鸟教程

上面的地址涵盖了angularJS的所有内置指令

ng-src:

如果直接给src绑定{{a}},后台会报错

如果使用ng-src就不会报错 。<img ng-src="{{a}}"

ng-cloak:

没加载之前先隐藏,在网速慢的时候,变量还未渲染时,不会显示{{}}空的字符串,而是这个div直接不显示

ng-href:

为防止页面还没有加载完毕时,客户五点了a标签却没有任何响应的问题 

ng-switch

 

ng-bind-html 和 ng-bind的区别:

 

 

 ng-bind 和 ng-bind-template:

使用ng-bind-template就可以输出

 ng-include:

 

ng-options

先来看使用普通方法ng-repeat渲染下拉:

 

再通过使用ng-options渲染下拉:

ng-options替你组织options

1、必须有ng-model

2、值 as 文字 for item in arr

 ng-options使用升级:

select下拉分组,group by xxx

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/336923.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网安行业,能力重要么?

网安职场&#xff0c;说能力不重要&#xff0c;那是扯淡&#xff1b;说能力重要的&#xff0c;那也是扯淡。职场不是能力的比拼&#xff0c;职场是修行的比拼&#xff0c;是成长的比拼。 我经常在公众号里讲&#xff0c;网安职场是熬出来的&#xff0c;网安人要忠于职业&…

【学习Day3】计算机基础

✍&#x1f3fb;记录学习过程中的输出&#xff0c;坚持每天学习一点点~ ❤️希望能给大家提供帮助~欢迎点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;指点&#x1f64f; 1.5.4 Cache替换算法 Cache的页面淘汰算法 常用替换算法有&#xff1a; • 随机替换算法RA…

23 vue3面试重难点复习:响应式原理、特点、8大生命钩子、data数据定义、组件、全家桶

vue作为用的最为广泛的当前热门框架&#xff0c;总结如下重难点核心知识&#xff1a; 1.vue特点是什么&#xff1f; 1.1优点 渐进式 vue本身只提供数据响应式&#xff0c;需要全局缓存用 vuex&#xff0c;需要路由用 vue-router 组件化 封装组件&#xff0c;利于复用 响应式数…

DSP开发入门

视频&#xff1a; 创龙TI 最新DSP CPU核心架构 C66x 以及 KeyStone I 架构 DSP TMS320C6655/57以及TMS320C6678视频教程全集_哔哩哔哩_bilibili 2024年硬汉科技手把手教您学DSP28335视频教程持续更新中_哔哩哔哩_bilibili DSP芯片介绍 DSP选型 TI的DSP 分为三大系列&#…

AI绘画Stable Diffusion【隐藏文字】:将艺术字隐藏在国风云雾山水图中

大家好&#xff0c;我是灵魂画师向阳 今天我们分享一下用AI绘画工具Stable Diffusion制作网上很火的隐藏文字。这里以将艺术字隐藏在国风云雾山水图为例进行讲解&#xff0c;下面我们就来看看吧。 一. 艺术字隐藏在国风云雾山水图中制作方法 【第一步】&#xff1a;制作底图…

预约直播丨ETLCloud训练营:ETL中多流数据合并与运算专题

在大数据处理领域&#xff0c;一个至关重要的步骤是对多源数据流进行汇聚与融合&#xff0c;进而开展深度处理与剖析。此操作对于构建高效数据仓库、实现数据动态变化的实时洞察&#xff0c;以及驾驭复杂事件流的处理机制尤为关键。过程涉及从多样化的数据源中抽取信息&#xf…

在PostGIS中检查孤线(Find isolated lines in PostGIS)

场景 在PostGIS中有一张线要素表,需要检查该表中的孤线,并且进行自动纠正的计算。 其中孤线定义为两端端点都不在任何其他线的顶点上。 本文介绍在PostGIS中的线要素点,通过函数计算指定线要素表中的孤线,并计算最接近的纠偏位置。 In PostGIS, there is a table of line …

【C++】开源:RabbitMQ安装与配置使用(SimpleAmqpClient)

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下次更新不迷路&#x1…

【UnityShader入门精要学习笔记】第十六章 Unity中的渲染优化技术 (上)

本系列为作者学习UnityShader入门精要而作的笔记&#xff0c;内容将包括&#xff1a; 书本中句子照抄 个人批注项目源码一堆新手会犯的错误潜在的太监断更&#xff0c;有始无终 我的GitHub仓库 总之适用于同样开始学习Shader的同学们进行有取舍的参考。 文章目录 移动平台上…

C语言(字符和字符串函数)2

Hi~&#xff01;这里是奋斗的小羊&#xff0c;很荣幸各位能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎~~ &#x1f4a5;个人主页&#xff1a;小羊在奋斗 &#x1f4a5;所属专栏&#xff1a;C语言 本系列文章为个人学习笔记&#xff0c;在这里撰写成文一…

漫谈企业信息化安全 - 零信任架构

一、引言 《万物简史》的作者比尔布来森说&#xff0c;当他小的时候学科学的时候&#xff0c;好像这些科学家们都是有一种本领&#xff0c;把科学总是以一种让人看不懂的方式说得神乎其神&#xff0c;好像有藏着什么不可告人的秘密。因此&#xff0c;想要写一本让大家都能看得…

Django ORM入门指南:从概念到实践,掌握模型创建、迁移与视图操作

系列文章目录 Django入门全攻略&#xff1a;从零搭建你的第一个Web项目Django ORM入门指南&#xff1a;从概念到实践&#xff0c;掌握模型创建、迁移与视图操作[Django ORM实战&#xff1a;模型字段与元选项配置&#xff0c;以及链式过滤与QF查询详解]还在写0.0… 文章目录 系…

开发语言Java+前端框架Vue+后端框架SpringBoot开发的ADR药物不良反应监测系统源码 系统有哪些优势?

开发语言Java前端框架Vue后端框架SpringBoot开发的ADR药物不良反应监测系统源码 系统有哪些优势&#xff1f; ADR药物不良反应监测系统具有多个显著的优势&#xff0c;这些优势主要体现在以下几个方面&#xff1a; 一、提高监测效率与准确性&#xff1a; 通过自动化的数据收集…

CAPL如何发送一条UDP报文

UDP作为传输层协议,本身并不具有可靠性传输特点,所以不需要建立连接通道,可以直接发送数据。当然,前提是需要知道对方的通信端点,也就是IP地址和端口号。 端口号是传输层协议中最显著的特征,传输层根据它来确定上层绑定的应用程序,以达到把数据交给上层应用处理的目的。…

使用PNP管控制MCU是否需要复位

这两台用到一款芯片带电池&#xff0c;希望电池还有电芯片在工作的时候插入电源不要给芯片复位&#xff0c;当电池没电&#xff0c;芯片不在工作的时候&#xff0c;插入电源给芯片复位所以使用一个PNP三极管&#xff0c;通过芯片IO控制是否打开复位&#xff0c;当芯片正常工作的…

LabVIEW与Simulink的通信及调用方式

LabVIEW和Simulink可以通过多种方式进行通信和集成&#xff0c;实现数据交互和功能调用。常见的通信方式包括TCP/IP、UDP、共享内存等&#xff0c;此外还可以利用MATLAB Script Node和S-Function等直接调用对方的功能。这些方法使得LabVIEW和Simulink能够协同工作&#xff0c;充…

element-plus中在表格校验输入的值

element-plus中在表格校验输入的值 效果&#xff1a; 注意事项&#xff1a;需要在表单套一个表格的字段 代码&#xff1a; <el-form :model"tableFrom" ref"tableDataRef" :rules"rules" style"margin: 0px !important;">&…

c语言基础:数组的运用以及在内存中的地址的理解

目录 目录&#xff1a; 1.数组作为函数参数 2.数组在内存中的存储 2.1数组名是什么&#xff1f; 2.2下面我们来探讨二维数组的各个名字表示什么 二维数组的首元素地址是什么呢&#xff1f; *arr表示的是什么呢 &#xff1f;&#xff08;arr是二维数组&#xff09; 1.数组作…

【NumPy】掌握NumPy的divide函数:执行高效的数组除法操作

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

【Python】解决Python错误报错:IndexError: tuple index out of range

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…