当前位置: 首页 > news >正文

1.什么是Angular?

Angular

Angular 是一个应用设计框架与开发平台,旨在创建高效而精致的单页面应用。

什么是Angular?

Angular 是一个基于 TypeScript 构建的开发平台。它包括:

  • 一个基于组件的框架,用于构建可伸缩的 Web 应用。
  • 一组完美集成的库,涵盖各种功能,包括路由、表单管理、客户端-服务器通信等。
  • 一套开发工具,可帮助你开发、构建、测试和更新代码

Angular 应用

1. 组件

组件是构成应用的砖块。组件包括三个部分:带有 @Component() 装饰器的 TypeScript 类、HTML 模板和样式文件。

1.1 @Component() 装饰器

@Component() 装饰器会指定如下 Angular 专属信息:

  • 一个 CSS 选择器,用于定义如何在模板中使用组件。模板中与此选择器匹配的 HTML 元素将成为该组件的实例。
  • 一个 HTML 模板,用于指示 Angular 如何渲染此组件。
  • 一组可选的 CSS 样式,用于定义模板中 HTML 元素的外观。

通过 ng g component hello-world 命令可以自动生成组件,如下所示:

import { Component } from '@angular/core';@Component({selector: 'hello-world',templateUrl: './hello-world.component.html',styleUrls: ['./hello-world.component.css']
})
export class HelloWorldComponent {}

下面是一个最小化的 Angular 组件:

import { Component } from '@angular/core';@Component({selector: 'hello-world',template: `<h2>Hello World</h2><p>This is my first component!</p>`
})
export class HelloWorldComponent {// The code in this class drives the component's behavior.
}

要使用此组件,请在模板中编写以下内容:

<hello-world></hello-world>

当 Angular 渲染此组件时,生成的 DOM 如下所示:

<hello-world><h2>Hello World</h2><p>This is my first component!</p>
</hello-world>

Angular 的组件模型提供了强大的封装能力和直观的应用结构。组件还能让你的应用更容易进行单元测试,并可以提高代码的整体可读性。

2. 模板

每个组件都有一个 HTML 模板,用于声明该组件的渲染方式。你可以内联它或用文件路径定义此模板。

2.1 插值(interpolation)

Angular 添加了一些语法元素以扩展 HTML,让你可以从组件中插入动态值。当组件的状态更改时,Angular 会自动更新已渲染的 DOM。此功能的应用之一是插入动态文本,如下例子所示。

import { Component } from '@angular/core';@Component ({selector: 'hello-world-interpolation',templateUrl: './hello-world-interpolation.component.html'
})
export class HelloWorldInterpolationComponent {message = 'Hello, World!';
}

这里 message 的值来自上面的组件类:

<!--这里所用的双花括号,代表 Angular 对其中的内容进行插值。-->
<p>{{ message }}</p>

当应用加载组件及其模板时,用户将看到以下内容:

<p>Hello, World!</p>
2.2 属性绑定

Angular 还支持属性绑定,以帮助你设置 HTML 元素的 Property 和 Attribute 的值,并将这些值传给应用的展示逻辑。

假设有以下的组件类:

import { Component } from '@angular/core';@Component ({selector: 'hello-world-bindings',templateUrl: './hello-world-bindings.component.html'
})
export class HelloWorldBindingsComponent {fontColor = 'blue';sayHelloId = 1;canClick = false;message = 'Hello, World';sayMessage() {alert(this.message);}
}

在模板中编写如下内容:

<!--这里所用的方括号,该语法表明你正在将 Property 或 Attribute 绑定到组件类中的值。-->
<p [id]="sayHelloId" [style.color]="fontColor">My color is {{ fontColor }}</p>

当应用加载组件及其模板时,用户将看到以下内容:

<p id="1" style="color: blue;">My color is blue</p>
2.3 声明事件监听器

通过在圆括号中指定事件名称来声明一个事件监听器。该事件监听器可以来监听并响应用户的操作,比如按键、鼠标移动、单击和触摸等。

在模板中编写如下内容:

<button type="button" [disabled]="canClick" (click)="sayMessage()">Trigger alert message</button>

当用户点击按钮时,将会调用组件类中的sayMessage()方法,显示 Hello, World

2.4 指令

可以用指令来为模板添加额外功能。Angular 中最常用的指令是 *ngIf*ngFor。你可以使用指令执行各种任务,比如动态修改 DOM 结构。

以下代码是 *ngIf 指令的例子:

import { Component } from '@angular/core';@Component({selector: 'hello-world-ngif',templateUrl: './hello-world-ngif.component.html'
})
export class HelloWorldNgIfComponent {message = "I'm read only!";canEdit = false;onEditClick() {this.canEdit = !this.canEdit;if (this.canEdit) {this.message = 'You can edit me!';} else {this.message = "I'm read only!";}}
}
<h2>Hello World: ngIf!</h2><button type="button" (click)="onEditClick()">Make text editable!</button><div *ngIf="canEdit; else noEdit"><p>You can edit the following paragraph.</p>
</div><ng-template #noEdit><p>The following paragraph is read only. Try clicking the button!</p>
</ng-template><p [contentEditable]="canEdit">{{ message }}</p>

Angular 的声明式模板可以将应用的逻辑和外观完全分开。模板基于标准 HTML,因此易于构建、维护和更新。

3. Angular CLI

Angular CLI 是开发 Angular 应用最快、最简单和推荐的方式。Angular CLI 能简化许多任务。

命令详情
ng build把 Angular 应用编译到一个输出目录中。
ng serve构建你的应用并启动开发服务器,当有文件变化时就重新构建。
ng generate基于原理图(schematic)生成或修改某些文件。
ng test在指定的项目上运行单元测试。
ng e2e构建一个 Angular 应用并启动开发服务器,然后运行端到端测试。

4. 自带库

你可以通过Angular平台,来引入 Angular 所提供的众多自带库,以扩展应用的功能。

详情
Angular 路由器高级的客户侧导航功能与基于 Angular 组件的路由机制。支持惰性加载、嵌套路由、自定义路径匹配规则等。
Angular 表单统一的表单填报与验证体系。
Angular HttpClient健壮的 HTTP 客户端库,它可以支持更高级的客户端-服务器通讯。
Angular 动画丰富的动画体系,用于驱动基于应用状态的动画。
Angular PWA一些用于构建渐进式 Web 应用(PWA)的工具,包括 Service Worker 和 Web 应用清单(Manifest)。
Angular 原理图一些搭建脚手架、重构和升级的自动化工具。用于简化大规模应用的开发。

搭建本地开发环境和工作区

1. 前提条件

要想在你的本地系统中安装 Angular,需要如下步骤:

需求详情
Node.jsAngular 需要 Node.js 的活跃 LTS 版或维护期 LTS 版。(参阅:https://nodejs.org/en)
npm 包管理器Angular、Angular CLI 以及 Angular 应用都要依赖 npm 包来实现很多特性和功能。要下载并安装 npm 包,你需要一个 npm 包管理器。本指南使用 npm 客户端命令行界面,该界面默认安装在 Node.js。要检查你是否安装了 npm 客户端,请在终端窗口中运行 npm -v。

2. 安装 Angular CLI

你可以使用 Angular CLI 来创建项目,生成应用和库代码,以及执行各种持续开发任务,比如测试、打包和部署。
要安装 Angular CLI,请打开终端/控制台窗口,并运行如下命令:

npm install -g @angular/cli

在 Windows 客户端计算机上,默认禁用 PowerShell 脚本的执行。要允许执行 npm 全局二进制文件所需的 PowerShell 脚本,你必须设置以下执行策略内容:

Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned

3. 创建工作区和初始化应用

我们是在 Angular 工作区的上下文中开发应用。要创建一个新的工作区和初始化应用:

  • 运行 CLI 命令 ng new <project-name>,其中<project-name>是 Angular 应用的名称,如:
ng new my-app
  • ng new 命令会提示你要把哪些特性包含在初始应用中。按 Enter 或 Return 键可以接受默认值。

Angular CLI 会安装必要的 Angular npm 包和其它依赖包。这可能要花几分钟的时间。
CLI 会创建一个新的工作区和一个简单的欢迎应用,随时可以运行它。

4. 运行应用

Angular CLI 中包含一个服务器,方便你在本地构建和提供应用。

  • 进入 workspace 文件夹,比如 my-app
  • 运行下列命令。
cd my-app
ng serve --open

ng serve 命令会启动开发服务器、监视文件,并在这些文件发生更改时重建应用。
--open(或者只用 -o 缩写)选项会自动打开你的浏览器,并访问 http://localhost:4200/。

相关文章:

1.什么是Angular?

Angular Angular 是一个应用设计框架与开发平台&#xff0c;旨在创建高效而精致的单页面应用。 什么是Angular&#xff1f; Angular 是一个基于 TypeScript 构建的开发平台。它包括&#xff1a; 一个基于组件的框架&#xff0c;用于构建可伸缩的 Web 应用。一组完美集成的库&am…...

Qt ListWidget

先创建QListWidgetItem&#xff1a; QListWidgetItem* pListItem1 new QListWidgetItem(QIcon(":/resources/editor.png"),u8"editor");QListWidgetItem* pListItem2 new QListWidgetItem(QIcon(":/resources/env.png"),u8"env");Q…...

微服务实战系列之加密RSA

前言 在这个时代&#xff0c;我们选择的人生目标已丰富多彩&#xff0c;秉持的人生态度也千差万别&#xff1a; 除了吃喝玩乐&#xff0c;还有科技探索&#xff1b; 除了CityWalk&#xff0c;还有“BookWalk”&#xff1b; 除了走遍中国&#xff0c;还有走遍世界&#xff1b; …...

Centos 里面为什么有的磁盘命名/dev/vda 有的是/dev/sda ?

环境&#xff1a; Centos7.9 问题描述&#xff1a; Centos 里面为什么有的磁盘命名/dev/vda 有的是/dev/sda ? 解决方案&#xff1a; 1.盘命名为/dev/vda或/dev/sda的差异主要取决于系统的安装方式和硬件架构。 /dev/sda是传统的磁盘命名方案&#xff0c;用于标识IDE、S…...

P9232 [蓝桥杯 2023 省 A] 更小的数(区间DP)

求大数字某连续部分反转后&#xff0c;比原数字小的个数 思路&#xff1a;自前向后遍历 ai是位于数字第i位的数字 aj是位于数字第j位的数字&#xff08;i<j&#xff09; ai>aj f[ai][aj]1; ai<aj f[ai][aj]0; aiaj f[ai][aj]f…...

【ArcGIS Pro二次开发】(77):ArcGIS Pro中图层的获取与解析

一、最简单的获取图层方式 通常情况下&#xff0c;如果要获取当前地图中的图层&#xff0c;可以用2种方法获取。 以下图为例&#xff1a; 一种是【map.Layers】属性获取&#xff0c;结果如下&#xff1a; 可以看出&#xff0c;这里只获取到了第一层级的图层&#xff0c;图层组…...

Robust Optimization, imperfect CSI, CSIT and CSIR

文章目录 写在前面CSI, CSIT and CSIR 写在前面 CSIT或者CSIR可不可以用来帮助实现隐蔽通信 人工噪声让窃听者估计出错误的信道。 CSI, CSIT and CSIR MIMO Minimum Total MSE Transceiver Design With Imperfect CSI at Both Ends 2009 TSP 多输入多输出 (MIMO) 系统已成为…...

【数据结构】栈详解

目录 1. 前言2. 栈2.1 栈的概念及结构2.2 如何实现栈2.3 数组栈实现2.3.1 top怎么确定2.3.2 栈顶插入2.3.2.1 栈顶插入分析2.3.2.2 栈顶插入代码实现 2.3.3 栈顶删除2.3.4 判空2.3.4.1 分析2.3.4.2 代码实现 2.3.5 栈的元素个数2.3.6 栈销毁2.3.7 栈访问数据 3. 源代码3.1 Stac…...

大结局!OpenAI创始人奥特曼和 Greg Brockman 将加入微软!!!

持续48小时的OpenAI政变大戏终于迎来了大结局&#xff01; 微软堪称最大赢家&#x1f4a5;&#x1f4a5;&#x1f4a5; 微软CEO刚刚宣布&#xff1a; 我们仍然致力于与 OpenAI 的合作伙伴关系&#xff0c;并对我们的产品路线图、我们在 Microsoft Ignite 上宣布的一切继续创…...

Linux QT交叉编译环境安装

参考链接 linux交叉编译Qt_linux qt 交叉编译-CSDN博客 关键点&#xff1a;编译脚本&#xff0c;放在qt源代码根目录的.sh文件 #!/bin/shcd ./qt-everywhere-src-5.12.9./configure -prefix /home/qsqya/compile/qt5.12.9/build \ -opensource \ -release \ -confirm-license…...

媲美有线操作,支持4KHz响应和无线充电的游戏鼠标,雷柏VT3S上手

对于无线鼠标来说&#xff0c;操作延迟和精度对游戏操作影响很大&#xff0c;常见的游戏鼠标至少都有1KHz的回报率&#xff0c;而雷柏今年已经出了很多支持4KHz回报的鼠标了&#xff0c;像是我现在用的这款VT3S游戏鼠标&#xff0c;就搭载了旗舰级的原相3395引擎&#xff0c;支…...

【Flask使用】全知识md文档,4大部分60页第3篇:状态cookie和session保持

本文的主要内容&#xff1a;flask视图&路由、虚拟环境安装、路由各种定义、状态保持、cookie、session、模板基本使用、过滤器&自定义过滤器、模板代码复用&#xff1a;宏、继承/包含、模板中特有变量和函数、Flask-WTF 表单、CSRF、数据库操作、ORM、Flask-SQLAlchemy…...

类方法,静态方法和实例方法的区别及应用场景

在 Python 中&#xff0c;有三种不同类型的方法&#xff1a;实例方法、类方法和静态方法。它们各自有不同的特点和应用场景&#xff1a; 实例方法&#xff08;Instance Method&#xff09;&#xff1a; 实例方法是最常见的方法类型&#xff0c;在方法定义中第一个参数通常被命…...

CleanMyMac X4.16免费版mac电脑一键清理电脑垃圾工具

但是&#xff0c;我最近发现随着使用时间的增加&#xff0c;一些奇奇怪怪的文件开始占据有限的磁盘空间&#xff0c;存储空间变得越来越小&#xff0c;系统占用空间越来越大&#xff0c;越来越多的无效文件开始影响我电脑的运行速度。 Mac的文件管理方式和Windows不太一样&…...

汽车级低压差稳压器LDO LM317BD2TR4G原理、参数及应用

LM317BD2TR4G主要功能特性分析 &#xff1a; LM317BD2TR4G 低漏 (LDO) 线性电压稳压器是一款可调 3 端子正向 LDO 电压器&#xff0c;能够在 1.2 V 至 37 V 的输出电压范围内提供 1.5 A 以上的电流。此电压稳压器使用非常简便&#xff0c;仅需两个外部电阻即可设置输出电压。另…...

多对多的创建方式与Ajax

模型层补充 MTV与MVC模型 MTV 全称 Models Templates Views 模型模板视图 MVC 全称 Models Views Controller 模型视图控制MTV: Django号称是MTV模型 MVC: 其实django本质也是MVC 拓展: vue框架:MVVM模型choices参数(数据库字段设计常见) choices使用 class User(models.Mod…...

【Linux网络】详解使用http和ftp搭建yum仓库,以及yum网络源优化

目录 一、回顾yum的原理 1.1yum简介 yum安装的底层原理&#xff1a; yum的好处&#xff1a; 二、学习yum的配置文件及命令 1、yum的配置文件 2、yum的相关命令详解 3、yum的命令相关案例 三、搭建yum仓库的方式 1、本地yum仓库建立 2、通过http搭建内网的yum仓库 3、…...

算法设计与分析算法实现——动态规划最大子段

输入&#xff1a;整数序列a1,a2,…,an 输出&#xff1a;序列的一个子段&#xff0c;其和Σak最大 注意&#xff1a;当所有整数都为负数时&#xff0c;定义最大子段和为0 使用动态规划&#xff0c;输入数组是a[n]&#xff1b; 状态转移方程dp[i]max(dp[i-1]a[i],a[i])——这个状…...

JavaWeb-JVM内存管理机制

JavaWeb-JVM内存管理机制 一、JVM内存管理概述1.1 什么是JVM内存管理1.2 物理内存与虚拟内存1.3 内核空间与用户空间二、java中哪些组建需要使用内存2.1 Java堆2.2 线程2.3 类和类加速器2.4 NIO2.5 JNI三、JVM内存结构3.1 PC寄存器3.2 Java栈3.3 堆3.4 方法区3.5 运行时常量池3…...

阿里云oss存储文件上传功能实现(保姆级教程)

先登录&#xff1a; 点击进入控制台 点击左上角导航栏按钮 搜索oss&#xff0c;点击进入 进入之后点击立即开通oss按钮&#xff0c;开通之后点击下图立即创建&#xff0c;弹出创建Bucket 填上Bucket名称&#xff0c;读写权限改为公共读。其他不变点击确定创建&#xff0c;完成…...

从A2L/HEX文件到实时标定:手把手教你用INCA搭建HIL台架测试环境(CAN 500K波特率设置)

从A2L/HEX文件到实时标定&#xff1a;手把手教你用INCA搭建HIL台架测试环境&#xff08;CAN 500K波特率设置&#xff09; 在汽车电控系统开发中&#xff0c;硬件在环&#xff08;HIL&#xff09;测试是验证控制器功能的关键环节。作为行业标准工具&#xff0c;ETAS INCA软件与H…...

别只盯着YOLO!用百元级OpenMV+STM32,5分钟搭建一个低成本运动追踪原型系统

百元级视觉方案实战&#xff1a;OpenMVSTM32运动追踪系统开发指南 当计算机视觉成为热门技术&#xff0c;许多初学者却被动辄数千元的GPU设备和复杂的深度学习框架劝退。其实&#xff0c;在嵌入式视觉领域&#xff0c;有一款仅需百元级的硬件——OpenMV&#xff0c;配合常见的S…...

AI4S企业品牌定位怎么做:从复杂能力到市场判断,企业到底卡在了哪一步

AI4S企业很容易处在一种特别典型的表达困境里&#xff1a;技术路线很清楚&#xff0c;研究能力很强&#xff0c;模型和数据体系也很完整&#xff0c;但对外一讲公司&#xff0c;常常会迅速陷入“讲技术越讲越深、讲价值越讲越虚”的局面。内部团队讲起来会很顺&#xff0c;因为…...

技术创业者如何用Bootstrapping模式实现零成本启动与快速验证

1. 从“灵光一现”到“现实骨感”&#xff1a;一个博士生创业者的第一课几年前&#xff0c;我还是个埋头在实验室里捣鼓能量收集技术的博士生&#xff0c;满脑子都是微瓦级的功率优化和晦涩的论文。有一天&#xff0c;盯着桌上那台崭新的iPad&#xff0c;一个念头突然蹦出来&am…...

创业7年,从树莓派外壳到自研电子秤,一个硬件工程师的“断臂求生”复盘

一位硬件工程师的七年创业启示录&#xff1a;技术理想与商业现实的碰撞 深夜的实验室里&#xff0c;示波器的荧光映照着一张疲惫的脸。第七次修改的PCB板静静躺在工作台上&#xff0c;旁边是已经冷透的第三杯咖啡。这是大多数硬件创业者再熟悉不过的场景——在技术完美主义与商…...

SoC设计中时钟域交叉(CDC)验证的关键技术与实践

1. 时钟域交叉&#xff08;CDC&#xff09;验证的核心挑战与解决方案在现代SoC设计中&#xff0c;多时钟域架构已成为常态。根据行业数据&#xff0c;一个中等复杂度的SoC通常包含15-30个异步时钟域&#xff0c;而高端处理器可能超过50个。这种架构带来了一个关键验证难题&…...

Node.js 实现 Xcursor 到 PNG 转换:解锁 Linux 光标资源的跨平台应用

1. 项目概述&#xff1a;从Xcursor到PNG的转换之旅 在Linux桌面环境中&#xff0c;鼠标光标主题通常以 .xcursor 或 .cursor 文件格式存在。这是一种专为光标设计的、支持多尺寸和多帧动画的二进制格式。然而&#xff0c;当你需要将这些光标用于网页设计、游戏开发、文档插…...

别再乱用cv2.findHomography了!OpenCV透视变换选对函数,图像拼接和文档矫正效率翻倍

OpenCV透视变换实战指南&#xff1a;如何精准选择cv2.findHomography与cv2.getPerspectiveTransform 在计算机视觉项目中&#xff0c;透视变换是实现图像对齐、文档矫正和全景拼接的核心技术。许多开发者虽然熟悉OpenCV的基本操作&#xff0c;却在面对cv2.findHomography和cv2.…...

VCS仿真卡住了别慌!用+vcs+loopdetect和pstack快速定位Hang死问题

VCS仿真卡住了别慌&#xff01;用vcsloopdetect和pstack快速定位Hang死问题 芯片验证工程师最头疼的瞬间&#xff0c;莫过于仿真运行到一半突然卡住&#xff0c;进度条停止不动&#xff0c;日志也不再更新——这就是典型的"Hang死"现象。面对这种情况&#xff0c;新手…...

OpenClaw安全审计工具:五维扫描与实时监控保障AI助手安全

1. 项目概述&#xff1a;为你的AI助手装上“安全爪”如果你正在使用OpenClaw&#xff0c;或者任何类似的AI助手框架&#xff0c;那么你很可能正面临一个被大多数人忽视的“影子风险”。我们热衷于为AI助手添加各种技能&#xff08;MCP服务器&#xff09;&#xff0c;优化提示词…...