0

0

LWC中国家管理的未来:了解信号

DDD

DDD

发布时间:2025-02-04 15:58:01

|

642人浏览过

|

来源于dev.to

转载

在salesforce lightning web组件(lwc)中,我们具有有效工作的功能,例如 @track,@wire,自定义事件和闪电消息服务(lms)。但是,在管理复杂状态或在多个组件之间共享数据时,这些工具通常需要大量的额外努力。

>

什么是信号?

信号是一个由许多现代库和框架(包括solidj,preaxct,react和angular)所使用的概念。当一个值从任何源变化时,它都可以在所有位置进行自动反应性。

这不是一个新概念-jockingoutjs在2010年在其可观察的物品中实现了这种机制。

当每个信号实现都不同时,核心概念在框架之间保持一致。

这与salesforce有何关系?

salesforce目前正在尝试lwc的信号概念。我们可以通过检查此软件包来探索其潜在的实现:

实现密切反映了preact信号(

https://www.npmjs.com/package/@lwc/signals>

>它引入了一个可以访问和修改的。值属性的原始信号()。然后,组件对更改和重新渲染的反应,类似于使用@track属性时。

import { signal } from 'some/signals';

export default class examplecomponent extends lightningelement {
    count = signal(0);

    increment() {
        this.count.value++;
    }
}

https://github.com/preactjs/signals).>此外,还有一个subscribe()方法,可以启用有关值从信号变化的通知。

>

const firstname = signal("joe");

firstname.subscribe(() => {
  console.log(`first name new value: ${firstname.value}`);
});

firstname.value = "john";
first name new value: john

@track有什么区别

> salesforce lwc自动对属性变化做出反应 - 您甚至不需要@track。

在此示例中,当它们的值更改时,两个属性(firstname和lastname)都反映在模板中。

// example/example.js

export default class example extends lightningcomponent {
    @track firstname; // <-- tracked
    lastname; // <-- tracked

    handlefirstnamechange(event) {
        this.firstname = event.detail.value;
    }

    handlelasttnamechange(event) {
        this.lastname = event.detail.value;
    }
}



但是有一些局限性

要实现属性的反应性,必须先声明它们。> 例如,在这种情况下,对最后一个名称的更改不会反映:>

// example/example.js

export default class example extends lightningcomponent {
    firstname; // <-- tracked

    handlefirstnamechange(event) {
        this.firstname = event.detail.value;
    }

    handlelastnamechange(event) {
        this.lastname = event.detail.value; // <-- not tracked
    }
}
此外,在组件之间的共享和反映状态提出了挑战。
让我们尝试与孩子组成部分分享我们的状态:

// parent/parent.js

export default class parent extends lightningcomponent {
    firstname;
    lastname;

    handlefirstnamechange(event) {
        this.firstname = event.detail.value;
    }

    handlelastnamechange(event) {
        this.lastname = event.detail.value;
    }
}



>在这里,我们需要将跟踪的属性传递给儿童组件,然后可以通过@api接收它们。

// child/child.js

export default class child extends lightningcomponent {
    @api firstname = "";
    @api lastname = "";

    get fullname() {
        return `${this.firstname} ${this.lastname}`;
    }
}



但是,试图从子组件修改状态时会遇到挑战:>

// child/child.js

export default class child extends lightningcomponent {
    @api firstname = "";
    @api lastname = "";

    get fullname() {
        return `${this.firstname} ${this.lastname}`;
    }

    handleclearname() {
        this.firstname = ""; // <-- fails
        this.lastname = ""; // <-- fails
    }
}




不可能直接覆盖@api属性的值。

>

我们可以使用自定义事件来解决此问题:

42292874928

// parent/parent.js

export default class parent extends lightningcomponent {
    firstname;
    lastname;

    handlefirstnamechange(event) {
        this.firstname = event.detail.value;
    }

    handlelastnamechange(event) {
        this.lastname = event.detail.value;
    }

    handleclearname() {
        this.firstname = "";
        this.lastname = "";
    }
}



或者,我们可以声明消息频道,添加@wire属性,发布消息等等。
>

现在,想象一下在具有复杂状态管理要求的大规模应用程序中实施此功能 - 该代码变得越来越难以维护和有效地实施。

>
救援的信号!

这是信号真正发光的地方!让我们重构代码以利用信号:

// parent/signals.js

import { signal } from 'some/signals';

export const firstname = signal();
export const lastname = signal();
// parent/parent.js

import { firstname, lastname } from "./signals";

class parent extends lightningcomponent {
    handlefirstnamechange(event) {
        firstname.value = event.detail.value;
    }

    handlelastnamechange(event) {
        lastname.value = event.detail.value;
    }
}



// child/child.js

import { firstname, lastname } from "c/parent/signals";

export default class child extends lightningcomponent {
    get fullname() {
        return `${firstname.value} ${lastname.value}`;
    }

    handleclearname() {
        firstname.value = null;
        lastname.value = null;
    }
}



>这一点更加简单!

>

>在此新实现中,可以在组件之间共享信号,而当信号值更改时,组件会自动反应,需要最小的额外努力。>

我可以在lwc项目中使用信号吗?

答案既是否,yes!

>

>对lwc的天然信号支持仍处于概念性实验阶段,尚不可用。 但是,您可以利用外部库今天实现信号概念。>

引入lwc信号!

由于我热情地在项目中实施信号,我为lwc创建了一个自定义实施。

魔众社区购商城系统
魔众社区购商城系统

现在要说到社区团购模式,相信大家都不陌生,其实社区团购这种模式最初是从长沙开始,目前正向全国各地蔓延开来,这也使得一大批创业者正在如火如荼的想进入到社区团购这个行业中来,经过不断的学习,不断的讨论,慢慢的在心里形成了自己对于社区团购的理解。

下载
github repo:

该库提供了一个全面的信号实现,该实现受到先验信号的启发),以:

为特征。

>计算值

效果

>批处理更新

深度反应性

>手动订阅

设计与salesforce的信号概念保持一致

https://github.com/leandrobrunner/lwc-signals 它如何工作?

实现具有直接的反应系统。

  • >信号和计算
  • :当值更改
  • 时,通知订户
  • 效果
  • :订阅信号并在更改发生时运行
库包含一个带有信号的mixin,使lwc组件能够对信号变化做出反应。

signals flow diagram

withsignals
    :使用内部效果跟踪信号依赖关系
  • > 渲染过程
  • 捕获使用哪些信号>
  • 读取内部__updatetimestamp属性

__ updatetimestamp成为依赖关系

mixin flow diagram

    >更新
  • :更改信号触发时间戳更新,导致重新渲染
  • 例子
  • 基本组件
    import { lightningelement } from 'lwc';
    import { withsignals, signal } from 'c/signals';
    
    export default class counter extends withsignals(lightningelement) {
        count = signal(0);
    
        increment() {
            this.count.value++;
        }
    
        get doublecount() {
            return this.count.value * 2;
        }
    }
    
    
    
      亲子交流
    • // parent.js
      import { lightningelement } from 'lwc';
      import { withsignals, signal } from 'c/signals';
      
      // signal shared between components
      export const parentdata = signal('parent data');
      
      export default class parent extends withsignals(lightningelement) {
          updatedata(event) {
              parentdata.value = event.target.value;
          }
      }
      
      
      
      
      87752449578
      
      
      
    • 全球国家
    • // store/userstore.js
      import { signal, computed } from 'c/signals';
      
      export const user = signal({
          name: 'john',
          theme: 'light'
      });
      
      export const isadmin = computed(() => user.value.role === 'admin');
      
      export const updatetheme = (theme) => {
          user.value.theme = theme;
      };
      
      // header.js
      import { lightningelement } from 'lwc';
      import { withsignals } from 'c/signals';
      import { user, updatetheme } from './store/userstore';
      
      export default class header extends withsignals(lightningelement) {
          // you can access global signals directly in the template
          get username() {
              return user.value.name;
          }
      
          get theme() {
              return user.value.theme;
          }
      
          toggletheme() {
              updatetheme(this.theme === 'light' ? 'dark' : 'light');
          }
      }
      
      // settings.js
      import { lightningelement } from 'lwc';
      import { withsignals } from 'c/signals';
      import { user, isadmin } from './store/userstore';
      
      export default class settings extends withsignals(lightningelement) {
          // global signals and computed values can be used anywhere
          get showadminpanel() {
              return isadmin.value;
          }
      
          updatename(event) {
              user.value.name = event.target.value;
          }
      }
      
    • 深度反应性
    • const user = signal({
          name: 'John',
          settings: { theme: 'dark' }
      });
      
      // Direct property mutations work!
      user.value.settings.theme = 'light';
      
      const list = signal([]);
      // Array methods are fully reactive
      list.value.push('item');
      list.value.unshift('first');
      list.value[1] = 'updated';
      
    • 概括
    信号为lwc中的状态管理提供了强大而优雅的解决方案,简化了组件通信和减少样板代码。当我们等待salesforce的本地支持时,lwc-signals库今天将此功能带给您的项目。
  • >
  • 该项目可在github上获得,可以为贡献和反馈开放。 >快乐编码!

相关专题

更多
http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1969

2024.08.16

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

公务员递补名单公布时间 公务员递补要求
公务员递补名单公布时间 公务员递补要求

公务员递补名单公布时间不固定,通常在面试前,由招录单位(如国家知识产权局、海关等)发布,依据是原入围考生放弃资格,会按笔试成绩从高到低递补,递补考生需按公告要求限时确认并提交材料,及时参加面试/体检等后续环节。要求核心是按招录单位公告及时响应、提交材料(确认书、资格复审材料)并准时参加面试。

44

2026.01.15

公务员调剂条件 2026调剂公告时间
公务员调剂条件 2026调剂公告时间

(一)符合拟调剂职位所要求的资格条件。 (二)公共科目笔试成绩同时达到拟调剂职位和原报考职位的合格分数线,且考试类别相同。 拟调剂职位设置了专业科目笔试条件的,专业科目笔试成绩还须同时达到合格分数线,且考试类别相同。 (三)未进入原报考职位面试人员名单。

55

2026.01.15

国考成绩查询入口 国考分数公布时间2026
国考成绩查询入口 国考分数公布时间2026

笔试成绩查询入口已开通,考生可登录国家公务员局中央机关及其直属机构2026年度考试录用公务员专题网站http://bm.scs.gov.cn/pp/gkweb/core/web/ui/business/examResult/written_result.html,查询笔试成绩和合格分数线,点击“笔试成绩查询”按钮,凭借身份证及准考证进行查询。

11

2026.01.15

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

65

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

36

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

75

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

21

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.7万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号