Magazine Internet

Deux outils puissants pour Javascript

Publié le 19 juin 2008 par Spawnrider @spawnrider

Il est parfois difficile de gérer aisément le chargement, l’organisation de ces scripts Javascript. Surtout lorsque les fichier sont nombreux et/ou que les librairies ne sont pas toutes compatibles entre elles. Il n’est pas toujours utile de charger toutes les librairies Javascript pour une page donnée.

Voici deux nouveaux Ajax Loader ou plutôt Javascript Loader dans le même genre que la Google Ajax Librairies que je vous avez déjà présenté.

L’idée étant de délégué à un framework ou un outil la gestion de vos différentes sources Javascript.

Module.Js

Ce framework très léger permet de charger, inclure, déclarer, cacher des sources de script via quelques lignes de codes.

Par exemple

  • Une inclusion :
  1. include(‘theModule.js’);
  • Un chargement de fichier :
  1. <script src="modules.js?<strong>./index.js</strong>"></script>

Archetypes.js

C’est un framework plus puissant qui en plus de traiter ce genre de problème permet également de fournir une architecture type sur laquelle vont reposer tous vos développements de Javascript.

C’est une sorte de templatisation de vos sources Javascript. Vous suivez donc un modèle bien particulier. Ce sont de bonnes pratiques.

Les dépendances sont gérées ainsi :

  1. dependencies: {
  2.     components: {
  3.         slideManager: "Slidy.components.slideManager",
  4.         slideChangeHandler: "Slidy.components.slideChangeHandler",
  5.         slideCounter: "Slidy.components.slideCounter"
  6.     },
  7.     lib: ["Slidy.libs.shjs.sh_main", "Slidy.libs.shjs.sh_javascript", "Slidy.libs.shjs.sh_html"],
  8.     css: ["Slidy.css.slidy", "Slidy.css.w3c-blue", "Slidy.libs.shjs.sh_typical"],
  9.     html: {
  10.         main: "Slidy.templates.container"
  11.     }
  12. }

En plus de la gestion de dépendances, vous pouvez également faire de la programmation orientée composant via ce puissant framework. Ce qui augmente la lisibilité du code et permet une maintenance plus facile. Ce schéma résume parfaitement l’idée du framework Archetype : Une approche orientée MVC et composant.

runtime

Le code est donc simplement organisé :

  1. Archetype.Component.Extend(["Archetype.component.graphicalComponent"], {
  2.         name:"Sample.component.graphicalFoobar",
  3.         /**
  4.          * Set up the Component dependencies
  5.          */
  6.         setup:{
  7.                 dependencies: {
  8.                         components:{foobar: "Sample.components.foobar"},
  9.                         lib:[],
  10.                         css:[],
  11.                         html:{main: "Sample.templates.foobarComponent"}
  12.                 }
  13.         },
  14.         /**
  15.          * Start the Component itself
  16.          * @constructor
  17.          */
  18.         initialize: function() {
  19.                 this.options = {
  20.                         max: 5,
  21.                         date: new Date(0),
  22.                         table: ["a","b","c","d","e"]
  23.                 }
  24.                 this.anchor = $("bodyContent");
  25.  
  26.                 Logger.debug("foobarGraphical has been instanciated!");
  27.  
  28.                 new this.components.foobar();
  29.                 Logger.debug("foobar launched from foobarComponent!");
  30.  
  31.                 this.render(this.anchor);
  32.                 Logger.debug("foobarGraphical rendered!");
  33.         },
  34.         /**
  35.          * Listen to "DateUpdate" event
  36.          */
  37.         onDateUpdate: function(eventName, date) {
  38.                 this.options.date = date;
  39.                 this.render(this.anchor);
  40.                 Logger.debug("foobarGraphical received a date: " + date);
  41.         },
  42.         /**
  43.          * Render the Component view and return it
  44.          */
  45.         renderViewAsString: function() {
  46.                 return this.templates.main.evaluate(this.options);
  47.         }
  48. });

Retour à La Une de Logo Paperblog