【AICon】探索八个行业创新案例,教你在教育、金融、医疗、法律等领域实践大模型技术! >>> 了解详情
写点什么

最受欢迎的 10 大 Angular 技巧

  • 2020-09-16
  • 本文字数:1077 字

    阅读完需:约 4 分钟

最受欢迎的10大Angular技巧

本文最初发布于 indepth.dev 网站,经原作者授权由 InfoQ 中文站翻译并分享。


今年 6 月,我和 Waterplea 接受了一个有趣的挑战:每天在 Twitter 上写一个 Angular 技巧。Angular 社区对此表示热烈欢迎。


我决定写一篇社区最喜爱的 10 个技巧的总结,并详细解释它们的概念。

让全局对象令牌化

最受欢迎的推文是关于全局对象的 DI 令牌。


在前端,我们习惯使用很多在任何作用域内都可用的全局对象。我们使用诸如 window、document、fetch 方法和 location 等对象。我们希望能一直见到它们。


但比如说,在 Angular Universal 或 Jest 测试环境中没有浏览器,没有 Window,也没有 DOM,那该怎么办呢。通过将全局对象作为令牌(token),你可以放心地使用、替换和测试代码。



如果你想了解更多有关令牌的信息,并加深对 Angular 依赖注入机制的了解,请查看我在 angular.institute 上关于 DI 的免费章节

扩展 Observable 或 Subject

我看到许多开发人员在他们的应用中创建了出色的服务。因为我们使用 RxJS,所以服务可以在其中包含一个 Observable 或 Subject 并对其进行一些数据转换。


你可以简化这类情况,从 Observable 或 Subject 扩展服务:


控件值为 ReplaySubject

在某些情况下,你需要订阅控件 valueChanges 并获取其当前值。不要重新发明轮子,只需这样做即可:


高 DPI 用户

你知道如何分辨使用高 DPI 屏幕的用户吗?


你可以这样做检查,并用原生媒体标签使你的应用更适合高 DPI 屏幕:


不要忘记管道!

管道 Angular 是非常强大的选项。它使我们能够遵循组件模板内部的声明性方法。令我有些难过的是,一些 Angular 开发人员不喜欢创建自己的管道,可其实你几乎可以在任何数据转换的场景中创建管道。


这是适用于许多情况的通用管道示例:


Banana in a box

它有很多名字:banana in a box、双向绑定、输入 - 输出,并且使用起来很方便,比如和 ngModel 配合就很好用。但是如何为你自己的组件实现它呢?


RxJS 是一个未开发的世界

使用 RxJS 时,我尝试检查 RxJS 运算符的所有参数和重载,原因是有许多隐藏的选项可以使你更快地编写更强大的流。


还有许多运算符不是很流行,但是可以用一行代码来解决你的特定问题。


我就发现了一个例子



还有一条关于 RxJS 的推文,是让你的组件更具可扩展性的小技巧。



另一个:可以帮助编写具有很好功能的微型.pipe 的运算符。


你甚至可以制作自己的 ngFor 替代品

最后一个:Angular 对于 for…of… 之类的指令有特殊的语法。这样,你可以创建自己的 ngFor。


例如,它可以是用于迭代映射的 ngFor。或一个简单的从一个数字迭代到另一个数字的 for:



英文原文

The 10 best Angular tips selected by the community


2020-09-16 14:411750
用户头像
小智 让所有人认同的文字称不上表达

发布了 408 篇内容, 共 377.5 次阅读, 收获喜欢 1972 次。

关注

评论

发布
暂无评论
发现更多内容

华为云应用中间件DCS系列—Redis实现(视频直播)消息弹幕

华为云PaaS服务小智

云计算 软件开发 华为云

8086汇编基础 debug E命令 改变指定地址的数据,可同时看新旧内容

万里无云万里天

汇编语言

构建高性能物联网数据平台:EMQX和CnosDB的完整教程

CnosDB

开源 时序数据库 emqx CnosDB

ubuntu下安装transition_amr_parser教程。

百度搜索:蓝易云

云计算 Linux ubuntu 运维 SEO

2024北京国际测控技术与仪器展览会

吹吹晚风

8086汇编基础 debug jmp 修改IP

万里无云万里天

汇编语言

Defi/LP云算力质押挖矿系统开发技术

V\TG【ch3nguang】

Defi/ULAB质押挖矿开发Solidity语言丨ULAB质押挖矿系统开发技术

V\TG【ch3nguang】

以数智化指标管理,驱动光伏能源行业的市场推进

Kyligence

绿色能源 数据管理

DeFi/NFT质押借贷(挖矿)系统模式开发

V\TG【ch3nguang】

PCE模型,FomoCat为何发起反Web3空气资产的社区试验

股市老人

8086汇编基础 debug mov 指定段内的内存单元存到寄存器中

万里无云万里天

汇编语言

Python - 字典4

小万哥

Python 程序员 软件 后端 开发

Mobpush厂商通道回执配置指南

MobTech袤博科技

智能推送

2023 Visual Studio Code 插件推荐:18 个提高开发效率的常用插件

小万哥

程序员 前端 vscode 后端 编辑器

景区旅游分销管理系统开发搭建

V\TG【ch3nguang】

Java IO 与 NIO:高效的输入输出操作探究

程序那些事

Java 程序那些事 面试秘籍

8086汇编基础 debug mov al,'a'或者mov ax,'ab'错误的

万里无云万里天

汇编语言

ES6新特性(一)

阡陌r

JavaScript ES6 模板字符串 解构赋值

Mobpush智能化精准推送,助力求职者快人一步

MobTech袤博科技

智能推送

PCE模型,FomoCat为何发起反Web3空气资产的社区试验

EOSdreamer111

ubuntu系统部署dzzoffice及安装onlyoffice插件教程。

百度搜索:蓝易云

Linux ubuntu 运维 onlyoffice DzzOffice

eth2.0质押挖矿机制系统开发部署逻辑【详情】

V\TG【ch3nguang】

IDO预售代币LP流动性质押挖矿系统技术开发

V\TG【ch3nguang】

出海 SaaS 企业增长修炼手册:聊聊 PLG 的关键指标、技术栈和挑战

Kyligence

数据分析 指标管理

手把手带你打一场时间序列实战—跑通baseline

打工人!

人工智能 机器学习 时间序列预测

定制化推送+精细化运营,Mobpush助力《迷你世界》用户留存率提升23%

MobTech袤博科技

智能推送

EVE-NG安装设备组件

小魏写代码

从实时数据库转战时序数据库,他陪伴 TDengine 从 1.0 走到 3.0

TDengine

时序数据库 ​TDengine

8086汇编基础 debug D命令 查看指定地址及其之后的128字节的内容

万里无云万里天

汇编语言

8086汇编基础 debug jmp 修改CS:IP

万里无云万里天

汇编语言

最受欢迎的10大Angular技巧_大前端_Roman Sedov_InfoQ精选文章