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. |
|
2 | up Specifica che il dito / pulsante si è spostato verso l'alto. |
|
3 | tap Specifica il verificarsi di azioni su e giù. |
|
4 | track Specifica il verificarsi di azioni su e giù. |
|
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.