写点什么

最受欢迎的 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:411953
用户头像
小智 让所有人认同的文字称不上表达

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

关注

评论

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

就在今天,浪潮云说第二期来啦

云计算

【Flutter 专题】92 图解 Dart 单线程实现异步处理之 Isolate (一)

阿策小和尚

Flutter 小菜 0 基础学习 Flutter Android 小菜鸟 7月日更

十二张图,一脚踹开消息队列的大门

三分恶

消息队列

公司内部使用的数仓命名规范

白贺BaiHe

大数据 数仓 数仓规范 7月日更

为啥Java应用迁移到容器后会出现OOM?

Java架构师迁哥

React 18探秘(上)

Teobler

大前端 React

在线base64加密解密工具

入门小站

工具

Spring到底应该学哪些内容?

冰河

spring aop ioc 注解驱动 依赖反转

【LeetCode】主要元素Java题解

Albert

算法 LeetCode 7月日更

见康乘拼团软件开发|见康乘拼团系统APP开发

多地“真金白银”力撑区块链,中西部欲弯道超车新赛道

CECBC

Python利器!Jupyter最大威胁终于来了

Jackpop

Python Jupyter Notebook

深入理解搜索引擎——初识query理解

药老算法

搜索引擎 中文分词 query理解 query纠错 query分析

领域驱动设计101 - 聚合

luojiahu

领域驱动设计 DDD

架构实战营模块8 课后作业

En wei

架构实战营

Rust从0到1-智能指针-Drop trait

rust smart pointer drop trait

IntelliJ IDEA必备7款Python插件

Jackpop

IDEA pycharm

2020年的焦虑与忧伤

Emotion

疫情 考研 研究生

腾讯一面 Java Phaser 并发编程的理解与应用

陈皮的JavaLib

Java 面试 多线程

测试开发之网络篇-常用命令

禅道项目管理

Linux 命令行

什么是数据集市

奔向架构师

数据仓库 数据架构 7月日更

凭借这5步,我30分钟学会了Python爬虫!

Jackpop

爬虫 爬虫教程

与微软、IBM同台 斯图飞腾Stratifyd入选G2文本分析Grid报告

妇与术(三):机器人可以没有性别,但关系技术离不开女性

脑极体

如何看待技术采用生命周期 | 【话题讨论】

耳东@Erdong

云原生 话题讨论 7月日更

pha挖矿/phala挖矿APP系统开发内容

魔方、齿轮、融合剂:当新ICT技术邂逅教育产业

脑极体

Linux之find exec

入门小站

Linux

Vue3 + TypeScript 开发实践总结

程序员海军

typescript 大前端 Vue3 框架

图的应用——关键路径

若尘

数据结构

🏆 【JVM 性能调优】「对象内存分配」输出常用参数

码界西柚

JVM 7月日更

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