Maison > interface Web > Voir.js > Qu'est-ce qui est basé sur les données dans vue.js

Qu'est-ce qui est basé sur les données dans vue.js

coldplay.xixi
Libérer: 2020-11-12 10:39:07
original
2504 Les gens l'ont consulté

Le pilote de données dans vue.js est que lorsque les données changent, les développeurs n'ont pas besoin de modifier manuellement le dom. Vuejs encapsule le mappage des données et les opérations des objets dom. se soucier du traitement logique des données.

Qu'est-ce qui est basé sur les données dans vue.js

[Recommandations d'articles connexes : vue.js]

Qu'est-ce que la gestion des données

La gestion des données est la plus grande fonctionnalité de vuejs. Dans vuejs, ce qu'on appelle basé sur les données signifie que lorsque les données changent, l'interface utilisateur change en conséquence et les développeurs n'ont pas besoin de modifier manuellement le dom.

Par exemple, si nous cliquons sur un bouton, le texte de l'élément doit être basculé entre oui et non. À l'ère du slash-and-burn jquery, nous suivions généralement ce processus pour la modification de page. Nous liions les événements aux boutons, puis obtenions l'objet dom de l'élément correspondant à la copie, puis modifiions la valeur de copie de l'objet dom en fonction du changer.

Pour le processus d'implémentation de cette fonction dans vuejs, il vous suffit de spécifier l'événement sur l'élément bouton et de déclarer les attributs de la copie correspondante. Lorsque vous cliquez sur l'événement, la valeur de l'attribut est modifiée, et le texte de l'élément correspondant peut être automatiquement commuté, nous n'avons pas besoin d'utiliser manuellement le dom comme avant.

En bref, vuejs nous aide à encapsuler le mappage entre les données et les opérations sur les objets DOM. Nous devons uniquement nous soucier du traitement logique des données. Les modifications dans les données peuvent naturellement notifier la page pour restituer la page. .

Cela nous apporte des avantages. Nous n'avons plus besoin d'opérer fréquemment le DOM dans le code. Dans les projets réels, une grande partie de notre code est modifiée manuellement après la modification des données. éléments de la page. Lorsque la page devient de plus en plus complexe, l'organisation du code de la page deviendra de plus en plus difficile à maintenir. Dans le même temps, les opérations fréquentes de JS sur le DOM entraîneront une forte probabilité d'erreurs dans le code de la page. L'affichage de la page sera intégré au code JS, ce qui ne sera pas favorable à la mise à niveau de l'affichage de la page.

Alors, comment vuejs réalise-t-il ce lecteur de données ?

Framework MVVM

Le lecteur de données de Vuejs est implémenté via le framework MVVM. Le framework MVVM contient principalement trois parties : modèle, vue et viewmodel.

  • Modèle : fait référence à la partie données, qui correspond au front-end est l'objet javascript

  • Vue : fait référence à la partie vue , qui correspond au front-end est dom

  • Viewmodel : est le middleware qui connecte les vues et les données

Quest-ce qui est basé sur les données dans vue.js

Les données (Modèle) et la vue (View) ne peuvent pas communiquer directement, mais doivent communiquer avec les deux parties via ViewModel. Lorsque les données changent, le viewModel peut surveiller le changement et avertir la vue d'apporter des modifications en temps opportun. De même, lorsqu'un événement est déclenché sur la page, viewMOdel peut également écouter l'événement et demander au modèle de répondre. Viewmodel est équivalent à un observateur, surveillant les actions des deux parties et informant l'autre partie à temps pour effectuer les opérations correspondantes.

Implémentation basée sur les données de Vue.js

Pour une implémentation basée sur les données, nous pouvons simplement implémenter cette fonction via un minuteur, qui surveille régulièrement les données des objets. surveille les changements de données et détermine s'il faut mettre à jour l'interface

    a = 1;
    function renderDom(){
        document.getElementById('app').innerHTML = '数据是' + a;
    }
    
    function watcher(method){
        var b = a;
        method.apply();
         return setInterval(function(){
           if(b != a){
                method.apply();
                b = a;
           }
        }, 1000)
    }
    watcher(renderDom);
Copier après la connexion

Bien sûr, vuejs ne peut pas être une implémentation aussi simple et violente. vuejs est piloté par les données en implémentant un observateur.

Quest-ce qui est basé sur les données dans vue.js

Tout d'abord, pendant le processus d'instanciation, vuejs parcourra l'option de données passée à l'option d'objet instancié, parcourra toutes ses propriétés et utilisera Object.defineProperty pour définir ces dernières. les propriétés sont converties en getters/setters.

En même temps, chaque objet d'instance a un objet d'instance d'observateur. Pendant le processus de compilation du modèle, il utilisera getter pour accéder aux attributs de données. À ce moment, l'observateur enregistrera les attributs de données utilisés en tant que dépendances. . Cela établit la connexion entre la vue et les données. Lorsque la dépendance aux données de notre vue de rendu change ultérieurement (c'est-à-dire que le générateur de données est appelé), l'observateur comparera si les deux valeurs ont changé, puis déterminera s'il doit notifier à la vue un nouveau rendu.

Cela permet d'obtenir ce que l'on appelle la vue basée sur les données.

Recommandations d'apprentissage gratuites associées : JavaScript (vidéo)

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!

Étiquettes associées:
source:php.cn
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