Polymer - Eventi

Gli eventi vengono utilizzati dagli elementi che possono comunicare con i cambiamenti di stato dell'albero DOM agli elementi principali e utilizza le API DOM standard per la creazione, l'invio e l'ascolto di eventi. Ilannotated event listeners vengono utilizzati da Polymer, che definisce i listener di eventi come piccoli blocchi di modello DOM e possono essere aggiunti ai figli DOM utilizzando annotazioni di eventi nel modello.

Esempio

L'esempio seguente aggiunge listener di eventi annotati nel modello. Crea un file chiamato index.html e inserisci il codice seguente.

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href="bower_components/polymer/polymer.html">
      <link rel = "import" href = "annotated-eventlistners.html">
   </head>
   
   <body>
      <template id = "myapp" is = "dom-bind">
         //tap event is part of gesture events that fires consistently across both mobile
         //and desktop devices
         <annotated-eventlistners on-tap = "myClick"></annotated-eventlistners>
      </template>
      
      <script>
         var myval = document.querySelector('#myapp');
         myval.myClick =  function(e) {
            console.log('Hello World!!!');
         };
      </script>
   </body>
</html>

Produzione

Per eseguire l'applicazione, accedere alla directory del progetto creato ed eseguire il comando seguente.

polymer serve

Ora apri il browser e vai a http://127.0.0.1:8000/. Di seguito sarà l'output.

Fare clic sul testo per vedere il risultato nella console come mostrato nella schermata seguente.

Eventi personalizzati

Gli eventi personalizzati possono essere attivati ​​utilizzando il costruttore CustomEvent standard e il metodo dispatchEvent dall'elemento host.

Considera il seguente esempio che attiva l'evento personalizzato dall'elemento host. Apri il file index.html e aggiungi il seguente codice al suo interno.

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "custom-event.html">
   </head>
   
   <body>
      <custom-event></custom-event>
      <script>
         document.querySelector('custom-event').addEventListener('customValue', function (e) {
            console.log(e.detail.customval); // true
         })
      </script>
   </body>
</html>

Ora crea un altro file chiamato custom-event.html e includi il codice seguente.

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "custom-event">
   <template>
      <h2>Custom Event Example</h2>
      <button on-click = "myClick">Click Here</button>
   </template>
   
   <script>
      Polymer ({
         is: "custom-event", myClick(e) {
            this.dispatchEvent(new CustomEvent('customValue', {detail: {customval: true}}));
         }
      });
   </script>
</dom-module>

Produzione

Esegui l'applicazione come mostrato nell'esempio precedente e vai a http://127.0.0.1:8000/. Di seguito sarà l'output.

Ora fai clic sul pulsante, apri la console e vedi il valore reale per l'evento personalizzato come mostrato nello screenshot seguente.

Ora ci spostiamo con "retargeting di eventi", che specifica il target dell'evento in cui l'elemento può essere rappresentato nello stesso ambito dell'elemento in ascolto. Ad esempio, l'obiettivo può essere considerato come un elemento nel documento principale, mentre si utilizza un listener nel documento principale, non in un albero ombra. È possibile fare riferimento al capitolo relativo allo styling delle ombre in polimero per ulteriori spiegazioni ed esempi.

Eventi di gesti

Gli eventi di gesti possono essere utilizzati per le interazioni dell'utente, che definiscono una migliore interazione sia sul tocco che sui dispositivi mobili. Ad esempio, l'evento tap fa parte degli eventi di gesti che si attivano in modo coerente su dispositivi mobili e desktop.

Puoi fare riferimento all'esempio per l'evento gesto spiegato all'inizio di questo capitolo, che utilizza on-tap evento che aggiunge listener di eventi annotati nel modello.

La tabella seguente elenca diversi tipi di tipi di eventi di gesti.

Sr.No. Tipo di evento e descrizione Proprietà
1

down

Specifica che il dito / pulsante è stato spostato verso il basso.

  • x - Fornisce la coordinata clientX per un evento.

  • y - Fornisce le coordinate del cliente per un evento.

  • sourceEvent - Specifica l'azione down causata dall'evento DOM.

2

up

Specifica che il dito / pulsante si è spostato verso l'alto.

  • x - Fornisce la coordinata clientX per un evento.

  • y - Fornisce le coordinate del cliente per un evento.

  • sourceEvent - Specifica l'azione su causata dall'evento DOM.

3

tap

Specifica il verificarsi di azioni su e giù.

  • x - Fornisce la coordinata clientX per un evento.

  • y - Fornisce le coordinate del cliente per un evento.

  • sourceEvent - Specifica l'azione di tocco causata dall'evento DOM.

4

track

Specifica il verificarsi di azioni su e giù.

  • x - Fornisce la coordinata clientX per un evento.

  • y - Fornisce le coordinate del cliente per un evento.

  • state - È una stringa di tipo che specifica lo stato di tracciamento.

  • dx - Apporta le modifiche in pixel orizzontalmente, quando si tiene traccia del primo evento.

  • dy - Apporta verticalmente le modifiche in pixel, quando si tiene traccia del primo evento.

  • ddx - Apporta le modifiche in pixel orizzontalmente, quando si tiene traccia dell'ultimo evento.

  • ddy - Apporta verticalmente le modifiche in pixel, quando si tiene traccia dell'ultimo evento.

  • hover() - Viene utilizzato per determinare l'elemento attualmente al passaggio del mouse.

Esempio

L'esempio seguente specifica l'uso dei tipi di eventi di gesti nel modello. Crea un file chiamato index.html e inserisci il codice seguente.

<!doctype html>
<html>
   <head>
      <title>Polymer Example</title>
      <script src = "bower_components/webcomponentsjs/webcomponents-lite.js"></script>
      <link rel = "import" href = "bower_components/polymer/polymer.html">
      <link rel = "import" href = "gesture-event.html">
   </head>
   
   <body>
      <gesture-event></gesture-event>
   </body>
</html>

Ora crea un altro file chiamato gesture-event.html e includi il codice seguente.

<link rel = "import" href = "bower_components/polymer/polymer-element.html">

//it specifies the start of an element's local DOM
<dom-module id = "gesture-event">
   <template>
      <style>
         #box {
            width: 200px;
            height: 200px;
            background: #D7D0B7;
         }
      </style>
      
      <h2>Gesture Event Types Example</h2>
      <div id = "box" on-track = "myClick">{{track_message}}</div>
   </template>
   
   <script>
      Polymer ({
         is: 'gesture-event', myClick: function(e) {
            switch(e.detail.state) {
               case 'start':
               this.track_message = 'Tracking event started...';
               break;
               case 'track':
                  this.track_message = 'Tracking event is in progress... ' +
                  e.detail.x + ', ' + e.detail.y;
               break;
               case 'end':
                  this.track_message = 'Tracking event ended...';
               break;
            }
         }
      });
   </script>
</dom-module>

Produzione

Esegui l'applicazione come mostrato nell'esempio precedente e vai a http://127.0.0.1:8081/. Ora inizia a trascinare il mouse nell'elemento, verrà visualizzato lo stato come mostrato nella schermata seguente.

Dopo aver trascinato il mouse nell'elemento, mostrerà lo stato di avanzamento del monitoraggio degli eventi come mostrato nello screenshot seguente.

Quando smetti di trascinare il mouse, terminerà l'evento di tracciamento sull'elemento come mostrato nello screenshot seguente.