? Programmation et appréhension

It’s unnecessary and complicated at almost every layer. At best I can congratulate someone for quickly and simply solving a problem on top of the shit that they are given. The only software that I like is one that I can easily understand and solves my problems. The amount of complexity I’m willing to tolerate is proportional to the size of the problem being solved.

I hate almost all software (cache)

Les deux derniers cours ont été dédiés au développement de petites fonctionnalités qui ont permis de révéler que la compréhension de JavaScript est bien éloignée de la pratique.

Deux points bloquants ont été remontés par les étudiants :

Syntaxe et abstraction

Du coup j’ai revu ma copie une dizaine de fois (merci ##openweb) pour arriver à l’abstraction suivante :

window.$ = selector => Array.from(document.querySelectorAll(selector))
window.$$ = document.querySelector.bind(document)
window.on = Node.prototype.on = Array.prototype.on = function(type, ...rest) {
    let listener
    if (typeof rest[0] === 'function') {
        listener = rest[0]
    } else {
        const [targetNodeName, innerListener] = rest
        listener = function(event) {
            if (event.target.nodeName.toLowerCase() === targetNodeName) {
                innerListener(event)
            }
        }
    }
    Array.concat(this).forEach(element => element.addEventListener(type, listener))
}
window.$.on = window.on.bind(document)
window.trigger = Node.prototype.trigger = function(type, detail) {
    const event = new CustomEvent(type, { detail: detail })
    this.dispatchEvent(event)
}
Array.prototype.trigger = function(type, detail) {
    this.forEach(element => element.trigger(type, detail))
}
window.$.trigger = window.trigger.bind(document)

Moins de 30 lignes pour réussir à avoir du JavaScript qui permette de sélectionner des éléments et d’y associer des évènements de manière plus simple dans un contexte didactique. Un tel code permettant ensuite d’écrire :

function tests() {
    // Attaching/passing events for all titles.
    $('h1').on('changeColor', event => {
        console.log('changeColor received', event.detail)
        event.target.classList.add(`turn-${event.detail.color}`)
    })
    $('h1').on('click', event => {
        // Intentionally overcomplicated :-).
        console.log('changeColor triggered', event.target)
        event.target.trigger('changeColor', {color: event.target.innerHTML})
    })
    // Event delegation for a single item (works with many too).
    $$('ul').on('click', 'a', event => {
        event.preventDefault()
        console.log(event.target.innerHTML)
    })
    // Anonymous pub/sub.
    $.on('anonymousEvent', event => {
        console.log('anoynmous event received')
    })
    $.trigger('anonymousEvent')
}
on('DOMContentLoaded', tests);

C’est déjà mieux. Si je devais aller plus loin, je pense que je me tournerais vers des solutions comme RiotJS qui ont une approche par composants web et une barrière à l’entrée relativement basse. Il y aurait du matériel pédagogique à créer dans ce domaine, peut-être plus utile qu’un n-ème framework JS/CSS.

Concepts et algorithmes

Ici le blocage se situe dans le découpage fonctionnel et la peur de la page blanche. Et aussi peut-être un peu dans l’appréhension qui entoure tout ce qui a trait au code.

J’ai essayé de les faire travailler en amont, de leur fournir un canvas où ils n’avaient plus qu’à compléter les parties manquantes, de commencer par définir la logique avant de coder mais aucune des approche n’a vraiment portée ses fruits. La contrainte de temps était peut-être trop importante pour ce que j’ambitionnais mais pour introduire des interactions avec l’utilisateur il faut au moins savoir manipuler des éléments et y associer des évènements… sinon on reste dans la théorie.

Les savoirs s’acquièrent dans le temps, la pratique et la répétition. Il est difficile d’évaluer l’impact que l’on peut avoir dans une transmission. Parfois cette itération sera percutante, parfois elle se révèlera dans la durée, d’autres fois elle aura été complètement inutile. Ces interrogations sont probablement le quotidien de tout enseignant.