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、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1991

2024.08.16

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

11

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

70

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

108

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

152

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

58

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

44

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

20

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

131

2026.01.15

热门下载

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

精品课程

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

共21课时 | 2.8万人学习

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号