Maison > interface Web > js tutoriel > Utilisation de l'API BroadcastChannel avec Vue pour synchroniser une référence sur plusieurs onglets

Utilisation de l'API BroadcastChannel avec Vue pour synchroniser une référence sur plusieurs onglets

DDD
Libérer: 2024-12-04 10:52:10
original
487 Les gens l'ont consulté

Using BroadcastChannel API with Vue to sync a ref across multiple tabs

Nous essayons de faire gagner du temps à tous les membres de notre équipe, pas seulement aux développeurs : certaines personnes passent beaucoup de temps à configurer notre application pour les clients ou les démos, nous veillons donc à ce qu'elle soit aussi fluide que possible. possible. Par exemple, nous essayons d'effectuer chaque modification en temps réel, il n'est donc pas nécessaire de recharger l'application pour que les modifications apparaissent.

Récemment, nous avons découvert que ces personnes travaillent généralement avec plusieurs onglets ouverts, en nous assurant que la configuration fonctionne comme prévu dans plusieurs pages de l'application. Nous avons donc pensé à synchroniser la configuration entre les onglets.

Nous n'avons pas souhaité le stocker, ni en session, ni en stockage local ni autre, car il faudra alors s'assurer qu'il soit toujours à jour.

C'est à ce moment-là que nous sommes tombés sur l'API BroadcastChannel, je ne savais même pas qu'elle existait. Ce n'est pas assez nouveau, mais Safari a été le dernier à l'implémenter selon CanIUse. Quoi qu'il en soit, il est largement pris en charge maintenant. Vous pouvez y penser comme au bon vieux window.postMessage() d'iframe, mais sur plusieurs onglets de même origine.

Heureusement pour nous, VueUse a déjà créé un petit composable pour faciliter son utilisation : https://vueuse.org/core/useBroadcastChannel/#usebroadcastchannel

const {
  isSupported,
  channel,
  post,
  close,
  error,
  isClosed,
} = useBroadcastChannel({ name: 'unique-name' })
Copier après la connexion

Nous avons donc créé un petit composable interne basé sur celui-ci pour nous assurer qu'une référence est toujours synchronisée entre tous les onglets :

import { useBroadcastChannel, watchPausable } from '@vueuse/core';
import { nextTick, watch } from 'vue';

import type { Ref } from 'vue';

export const useSync = <T>(value: Ref<T>, name: string, options?: { immediate?: boolean; deep?: boolean }) => {
  // Name must be unique
  const { post, data } = useBroadcastChannel<T, T>({ name });

  // When value changes locally, update other tabs
  const { pause, resume } = watchPausable(
    () => value.value,
    (newValue) => {
      post(structuredClone(newValue));
    },
    options,
  );

  // When value changes in another tab, update it locally
  watch(
    () => data.value,
    async (newValue) => {
      // Prevent watch loop when updating config
      pause();
      value.value = newValue;
      await nextTick();
      resume();
    },
    options,
  );
};
Copier après la connexion

Nous pouvons donc maintenant synchroniser une référence avec une seule ligne :

const config = ref({})
useSync(config, 'config', { deep: true });
Copier après la connexion

Et voilà ! Cela fait quelques heures gagnées chaque mois au sein des équipes ?

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal