Angular等了三年,那个她已经来了

简介: Angular,尽管功能强大且生态丰富,但面临设计变更和历史包袱问题,如NgModule与Standalone、zone.js与Signals、Rxjs的复杂性。其响应式系统不易使用,对tsx支持不佳,IOC容器繁琐,模块化隔离不足。为解决这些问题,推荐尝试 Cabloy-Front,一个基于Vue3的框架。Cabloy-Front提供更好的响应式系统、tsx支持、简化IOC容器,实现更强的模块化隔离和优雅的开发体验。代码示例展示了其如何简化响应式状态定义、逻辑抽离和注入。

Angular生态丰富,功能强大,支撑了许多大型项目的开发。而且一直在前方等待着其他框架跟上。但是不得不直面的一个问题就是:“在等待其他框架跟上的这三年”,Angular在陆陆续续抛弃之前引以为豪的设计。又由于大量的历史包袱,这些设计变更又做得扭扭捏捏,做不到轻装上阵。比如NgModule之于Standalone,zone.js之于Singals,Rxjs更是一言难尽

Angular虽然有许多超前的架构设计和工程化能力,但是就目前而言,仍有以下不足:

  1. 响应式系统不好用:即便是新引入的Signal,如果要访问一个状态值,需要像函数一样调用,这是反直觉的实现方式
  2. 对tsx支持不友好:全网很难找到angular+tsx的最佳实践。单靠模版,支撑大型业务系统的开发,难度是很大的
  3. ioc容器太过繁琐:看看文档就知道了,angular劝退新人的点很多,ioc繁琐是最主要的
  4. 模块化隔离性不够好,拖泥带水:虽然angular引入了模块化概念,但是模块之间隔离不彻底。比如我在A模块实现了一个service,如果要在B模块使用,就需要明确指定service在A模块的文件路径,而不是指定一个名称就行。这样就让模块耦合很深。类似这样的设计问题还有很多

Cabloy-Front就很好的解决了angular的这些短板。Cabloy-Front是一款支持ioc容器的Vue3框架,有以下特点:

  1. 底层采用vue3的响应式系统:在ioc容器的加持下,定义响应式状态不再需要ref/reactive,也不再需要ref.value
  2. 在独立的render class中书写tsx代码,从而让tsx代码更加舒展、从容
  3. 提供了两类ioc容器:一类是全局ioc容器,可以实现pinia的能力。另一类是组件实例ioc容器,该容器与Vue组件实例绑定,在这个容器中的所有 Class 实例都可以在组件实例范围之内共享数据和逻辑
  4. 模块化体系:实现了完全隔离的模块化体系。模块作为一个相对独立的业务单元,包含各种类型的资源,包括Config配置、Constant常量、Locale国际化、Error错误异常、Component组件,等等。在跨模块访问这些资源时,是基于名称寻址,而不是基于资源的原始文件路径寻址,因此,心智负担更低
  5. 更优雅的ioc容器开发体验:采用依赖注入依赖查找相结合的方式,大量减少装饰器的使用,让代码更简洁、更优雅。优先使用依赖查找的机制可以达到化类型于无形的效果?简而言之,就是无须标注类型,却能享受到“类型约束”和“智能提示”的好处

口说无凭,我们简单看一下cabloy-front的代码风格是怎样的:

  1. 定义响应式状态

在组件中定义一个响应式变量count,并且添加两个方法修改变量

export class MotherPageCounter {
  count: number = 0;
  inrement() {
    this.count++;
  }
  decrement() {
    this.count--;
  }
}
  1. 使用响应式状态

采用tsx语法使用count

export class RenderPageCounter {
  render() {
    return (
      <div>
        <div>count(ref): {this.count}</div>
        <button onClick={() => this.inrement()}>Inrement</button>
        <button onClick={() => this.decrement()}>Decrement</button>
      </div>
    );
  }
}
  1. 逻辑抽离

将count逻辑抽离出来,创建一个Counter Bean

@Local()
export class Counter {
  count: number = 0;
  inrement() {
    this.count++;
  }
  decrement() {
    this.count--;
  }
}
  1. 在组件中注入并使用

使用装饰器函数@Use注入bean

export class MotherPageCounter {
  @Use()
  $$counter: Counter;
}

采用tsx语法使用已注入的bean实例

export class RenderPageCounter {
  render() {
    return (
      <div>
        <div>count(ref): {this.$$counter.count}</div>
        <button onClick={() => this.$$counter.inrement()}>Inrement</button>
        <button onClick={() => this.$$counter.decrement()}>Decrement</button>
      </div>
    );
  }
}
相关文章
|
JavaScript Java 开发工具
Angular学习前期准备
Angular学习前期准备
137 0
Angular学习前期准备
|
JavaScript 前端开发 容器
angular36-todoMVC准备工作
angular36-todoMVC准备工作
90 0
angular36-todoMVC准备工作
|
API
Angular 2.x折腾记 :(3)初步了解服务及使用
不探究高深理论,只探究实际使用,有更好的写法或者经验请指出; 有些暂时没涉及到的知识我可能会顺着例子解释;
153 0
|
JavaScript
初露锋芒 Angular6 入门项目 - 2
初露锋芒 Angular6 入门项目 - 2
241 0
|
前端开发
Angular 应用是怎么工作的?
你是否好奇 Angular 应用背后场景都发生了什么?
Angular 应用是怎么工作的?
|
前端开发 JavaScript Java
|
前端开发 JavaScript 监控
Angular 6.0已发版: Angular快速入门
Angular 6.0.0 于2018年5月4日正式发布,今天我们一起来跟着其官网(https://angular.io/guide/quickstart)的例子做个简单入门吧!
2879 0
|
JavaScript API
angular6 render2 & viewContentRef实践
angular 渲染层   angular一个跨平台的框架不仅仅针对的浏览器这一个平台 ElementRef 与 TemplateRef   简单的理解:                ElemnetRef : 例如一个元素的引用;                TemplateRef: 例如template模板的引用; 再angular中,官方的说法是: 不推荐使用ElementRef来改变元素的样式属性值或者操作DOM元素,原因是,angular是一个跨平台的框架,如果直接使用ElementRef对DOM直接进行操作,那么在其他平台情况下会出事。
2259 0