Copier des données dans le clipboard en JavaScript

Comment copier des données quelconques dans le clipboard en JavaScript dans le contexte d’une page Web ? Ce problème est assez simple à régler. Il suffit d’ajouter un gestionnaire de l’événement copy à l’objet document.
Le problème se complique s’il est exigé que ce gestionnaire d’événement soit anonyme et par ailleurs qu’il soit strictement éphémère, c’est-à-dire qu’il se retire de l’objet document une fois que l’événement copy est survenu, comme ce serait le cas si l’utilisateur cliquait sur un bouton « Copier » à usage ponctuel. En effet, en mode strict, il n’est plus possible d’utiliser arguments.callee pour faire référence à une fonction anonyme dans le corps de cette dernière. Par conséquent, impossible de faire référence à la fonction dans un appel à removeEventListener ().

Continuer la lecture de « Copier des données dans le clipboard en JavaScript »

Copier des données dans le clipboard en JavaScript

Itérateur et générateur en JavaScript

Comment créer facilement une liste d’éléments qu’il sera possible de parcourir à l’aide de l’instruction for… of… (à ne pas confondre avec for… in…) ?
Cette liste doit pouvoir être totalement spécifique, et non seulement une liste prédéfinie dans JavaScript, comme notamment un tableau. En particulier, ses éléments doivent pouvoir n’être générés qu’au fil de l’itération.

Continuer la lecture de « Itérateur et générateur en JavaScript »

Itérateur et générateur en JavaScript

Closures pour gérer les événements en JavaScript

La fonction addEventListener () permet d’associer une fonction (le gestionnaire d’événement) à un événement. Lorsque l’événement survient, le navigateur appelle le gestionnaire d’événement en lui transmettant un unique argument sous la forme d’un objet décrivant l’événement.
Comment transmettre autre chose à ce gestionnaire, comme par exemple une référence sur un objet spécifique ?

Continuer la lecture de « Closures pour gérer les événements en JavaScript »

Closures pour gérer les événements en JavaScript