Angular2入门--架构总览
发布时间 - 2026-01-11 00:24:51 点击率:次大致介绍

在3月23日,Angular4正式发布(没有3)。似乎现在学Angular2又晚了,又晚一步-_-||。Angular2在Angular1的基础上有了较大的改变。之前向一个同学(之前学过Angular1)问一个Angular2的问题,他反问到这是Angular代码? 可见Angular1->Angular2的变化有多大。先来看看Angular2的架构
核心模块
一个完整的Angular应用主要由六个重要部分组成:组件、模板、指令、服务、依赖注入和路由
他们之间的关系:
从图中可以看出:
1、与用户交互的是模板视图,模板和组件类共同组成组件
2、路由是控制组件的创建和销毁,从而驱使界面切换
3、指令和模板相关联,扩展了模板的语法
4、服务是封装若干个功能逻辑的单元,通过依赖注入引入组件内部
组件
Angular框架是基于组件设计,组件负责控制屏幕上的一小块区域,例如网页的导航栏就是一个组件
一个组件的代码:
import { Component, Input } from '@angular/core';
import { Hero } from './hero';
@Component({
selector: 'my-hero-detail',
template: `
<div *ngIf="hero">
<h2>{{hero.name}} details!</h2>
<div><label>id: </label>{{hero.id}}</div>
<div>
<label>name: </label>
<input [(ngModel)]="hero.name" placeholder="name"/>
</div>
</div>
})
export class HeroDetailComponent {
@Input()
hero: Hero;
}
模板
我们通过组件的自带的模板来定义组件视图。模板以 HTML 形式存在,告诉 Angular 如何渲染组件。
例如上面组件中的@Component中就是模板
@Component({
selector: 'my-hero-detail',
template: `
<div *ngIf="hero">
<h2>{{hero.name}} details!</h2>
<div><label>id: </label>{{hero.id}}</div>
<div>
<label>name: </label>
<input [(ngModel)]="hero.name" placeholder="name"/>
</div>
</div>
})
指令
指令和模板的关系密切,指令可以与DOM进行灵活交互,可以改变样式也可以修改DOM。一般的指令都作用在已有的DOM元素上
1、修改DOM
<button *ngIf="canEdit">编辑</button>
当canEdit为true时,button会显示,否则,button隐藏
2、改变元素样式
<button [ngStyle]="setStyles()">编辑</button>
setStyles()是一个函数,可以通过这个函数修改元素的样式
服务
服务是封装单一功能的单元,常被引用于组件内部,作为组件的功能扩展。它可以是一个简单的字符串或是JSON数据,也可以是一个函数甚至是一个类
组件本身不从服务器获得数据、不进行验证输入,也不直接往控制台写日志。 它们把这些任务委托给服务。
一个简单的服务(包含一个类):
export class Hero {
id: number;
name: string;
}
依赖注入
通过依赖注入机制,服务等模块可以被引入到任何一个组件中,而开发者无需关心这些模块是如何被初始化的。因为Angular已经帮你处理好了,包括本模块本身依赖的其他模块也会被初始化
路由
路由它把浏览器中的URL看做一个操作指南, 据此导航到一个由客户端生成的视图,并可以把参数传给支撑视图的相应组件,帮它决定具体该展现哪些内容。 我们可以为页面中的链接绑定一个路由,这样,当用户点击链接时,就会导航到应用中相应的视图。 当用户点击按钮、从下拉框中选取,或响应来自任何地方的事件时,我们也可以在代码控制下进行导航。 路由器还在浏览器的历史日志中记录下这些活动,这样浏览器的前进和后退按钮也能照常工作。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# angular2
# 架构
# angular2入门
# AngularJS入门教程之MVC架构实例分析
# Angular 4.0学习教程之架构详解
# 是一个
# 的是
# 这是
# 就会
# 也不
# 好了
# 也会
# 还在
# 基础上
# 也能
# 帮你
# 我们可以
# 可以通过
# 相关联
# 它可以
# 任何一个
# 可以看出
# 有多大
# 晚了
# 自带
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
使用spring连接及操作mongodb3.0实例
jQuery 常见小例汇总
如何在VPS电脑上快速搭建网站?
Linux系统命令中tree命令详解
用v-html解决Vue.js渲染中html标签不被解析的问题
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
Laravel如何使用withoutEvents方法临时禁用模型事件
怎么用AI帮你为初创公司进行市场定位分析?
JavaScript如何实现继承_有哪些常用方法
如何确认建站备案号应放置的具体位置?
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明
Laravel怎么实现模型属性的自动加密
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
Laravel怎么调用外部API_Laravel Http Client客户端使用
Laravel如何实现模型的全局作用域?(Global Scope示例)
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
高端网站建设与定制开发一站式解决方案 中企动力
bootstrap日历插件datetimepicker使用方法
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
焦点电影公司作品,电影焦点结局是什么?
Mybatis 中的insertOrUpdate操作
为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】
简单实现Android文件上传
高性能网站服务器配置指南:安全稳定与高效建站核心方案
利用JavaScript实现拖拽改变元素大小
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Laravel Session怎么存储_Laravel Session驱动配置详解
Laravel如何创建和注册中间件_Laravel中间件编写与应用流程
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
Laravel如何使用Blade模板引擎?(完整语法和示例)
制作旅游网站html,怎样注册旅游网站?
BootStrap整体框架之基础布局组件
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
如何在万网自助建站中设置域名及备案?
太平洋网站制作公司,网络用语太平洋是什么意思?
网站制作壁纸教程视频,电脑壁纸网站?
Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录
网站制作软件有哪些,制图软件有哪些?
PythonWeb开发入门教程_Flask快速构建Web应用
JavaScript常见的五种数组去重的方式
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
千库网官网入口推荐 千库网设计创意平台入口
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
java获取注册ip实例
Laravel怎么生成URL_Laravel路由命名与URL生成函数详解
如何用IIS7快速搭建并优化网站站点?
详解Android中Activity的四大启动模式实验简述

