• 开发vue3,真的可以不用ref/reactive了,也不需要ref.value


    什么是Cabloy-Front?

    Cabloy-Front 是一款支持 IOC 容器的 Vue3 框架。不用ref/reactive,不用ref.value,不用pinia

    与UI库的配合

    Cabloy-Front 可以搭配任何 UI 库使用,并且内置了几款 UI 库的项目模版,便于开箱即用,包括:

    • antdv
    • element-plus
    • quasar
    • vuetify

    特性

    Cabloy-Front 为 Vue3 引入了以下鲜明特征:

    • 不用ref/reactive:因为在大多数场景下,不需要使用 ref 和 reactive
    • 不用ref.value:因为在 Cabloy-Front 中定义响应式变量更加直观,不再需要 ref 语义
    • 不用pinia:因为 Cabloy-Front 提供了 IOC 容器,可以更加灵活的定义和使用全局对象

    动图演示

    No ref/reactive

    演示:不用ref/reactive,不用ref.value

    1. 定义响应式状态

    @Local()
    export class MotherPageCounter extends BeanMotherPageBase {
      counter: number = 0;
    
      inrement() {
        this.counter++;
      }
    
      decrement() {
        this.counter--;
      }
    }
    

    2. 使用响应式状态

    @Local()
    export class RenderPageCounter extends BeanRenderBase {
      render() {
        return (
          <div>
            <div>counter(ref): {this.counter}div>
            <button onClick={() => this.inrement()}>Inrementbutton>
            <button onClick={() => this.decrement()}>Decrementbutton>
          div>
        );
      }
    }
    

    演示:依赖注入

    1. 逻辑抽离

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

    @Local()
    export class LocalCounter extends BeanBase {
      counter: number = 0;
    
      inrement() {
        this.counter++;
      }
    
      decrement() {
        this.counter--;
      }
    }
    

    2. 在组件中注入并使用

    @Local()
    export class MotherPageCounter extends BeanMotherPageBase {
      @Use()
      $$counter: LocalCounter;
    }
    
    @Local()
    export class RenderPageCounter extends BeanRenderBase {
      render() {
        return (
          <div>
            <div>counter(ref): {this.$$counter.counter}div>
            <button onClick={() => this.$$counter.inrement()}>Inrementbutton>
            <button onClick={() => this.$$counter.decrement()}>Decrementbutton>
          div>
        );
      }
    }
    

    框架已开源: https://github.com/cabloy/cabloy-front

  • 相关阅读:
    minio网站登录invalid Login怎么解决
    UE5 ChaosVehicles载具换皮 (连载二)
    【Hello Go】Go语言并发编程
    嵌入式分享合集99
    集合-Map系列
    微信小程序开发17 日志监控:怎样面向业务设计日志方案?
    2D函数优化实战
    iPhone通讯录如何完整导入到新手机
    MD5校验判断文件是否一样
    【嵌入式】STM32F031K4U6、STM32F031K6U6、STM32F031K6T6主流ARM Cortex-M0基本型系列MCU规格参数
  • 原文地址:https://www.cnblogs.com/zhennann/p/18195691