Friday, November 23, 2012

Pattern MVC BackboneJs

L'objectif de cet article est de proposer plusieurs modélisation UML d'un projet de WebApplication avec la librairie Javascript BackboneJs.

Router > View > Model

Tout d'abord une modélisation très simple, qui comprend un router, une view et un model. 

Modélisation UML Architecture simple Backbone

Cette modélisation est un bonne solution si on est dans un contexte relativement simple. C'est à dire que l'on a qu'un seul Model, que l'on affichera grâce à le View.

Le router permet d'instancier la view à laquelle il passera le model à afficher.

  1. Router = Backbone.Router.extend({
  2.   routes: {
  3.          "Page1": "maPage1",   // http://monsite/#Page1
  4.          "*actions" : "defaultRoute" //http://monsite/
  5. },
  6. maPage1 : function(){
  7.      var view = new MaView({model : monModel, viewContainer : monContainer})
  8. }
  9. });

Router > Collection Model > View

Maintenant passons à une modélisation un peu plus complexe.
Modélisation UML avec une collection de model

 Cette fois on souhaite afficher une liste de model. Dans cette architecture, la View permet l'affichage d'une collection de Model. 
C'est à dire que dans la fonction Render(), nous allons faire un foreach() pour chaque élément de la liste, et générer directement le code HTML que l'on ajoutera à notre conteneur HTML de la liste.
  1. render : function (){
  2.      this.collection.each(function (item){
  3.              myContainterListe.append($(template(item.toJSON())));
  4.      }
  5. }

Ce principe n'est pas optimal notamment si l'on souhaite gérer des évènements sur les items de la liste générée par le View. 

Router > Collection > View > Model > View 

L'architecture présentée ci-dessous à une granularité plus fine que celle ci-dessus. 
Modélisation UML avec une view pour la collection et une view par item

On souhaite toujours afficher une liste de Model, mais à la différence le modélisation précédente, on crée une view pour la collection et une view pour les items de la collection.

Cette fois la fonction render() de la View de la collection, va faire appel ,pour chaque item, à la fonction Render() de la view des items.

  1. ListView = Backbone.View.extend({
  2.         renderItem: function(model){
  3.               var itemView = new ItemView({model : model});
  4.               itemView.render();
  5.         },
  6.         render : function() {
  7.                this.collection.each(this.renderItem);
  8.         }
  9. });


On pourra donc ajouter des évènements sur notre view Item, pour ajouter du comportement à nos items.

Pour ajouter des évènements sur une Backbone.View :


  1.  events :
  2. {
  3.      "click .classname" : "mafonction"
  4. }



Friday, November 16, 2012

(function ($) { }(jQuery)); vs $(function () {});

(function ($) {  }(jQuery)); vs $(function () {});

Un petit retour d'expérience, après être resté bloquer pendant quelques heures, sur une erreur liée à la librairie JqueryMobile. L'erreur est : $.mobile.loader of 'undefined' .

Contexte de l'erreur

  • dans la fonction (function($) {} (jQuery)); je crée un model Backbone, une view Backbone et un routeur Backbone.
  • dans cette même fonction j'instancie mon routeur et Backbone.history.start();
Lorsque je charge la page, je réalise un appel Ajax async pour obtenir une collection d'éléments. Pendant cette appel Ajax, j'utilise la "loading bar" de JQuery Mobile comme ci-dessous :
  1. CollectionModel.fetch({
  2.             beforeSend:function ()
  3.             { $.mobile.loading('show');
  4.             },
  5.             complete: function () {
  6.                 $.mobile.loading('hide');
  7.             }, 
  8.             success: callback
  9.         });
Lors de cette appel, la méthode $mobile.loading n'est pas définit car la librairie JQueryMobile n'est pas encore ready.

Solution

Pour résoudre le problème, il faut tout simplement réaliser l'instanciation du Router et lancé Backbone.history.start() n'ont pas dans (function($) {}(jQuery)) mais plutôt dans $(function() {}); car dans ce cas, on est sur que la librairie $.mobile est chargée et disponible.

La fonction anonyme (function($) {}(jQuery) signifie que le DOM JQuery est ready mais il faut bien dissocier le DOM JQuery et le DOM du Document qui est représenté par la fonction suivante : 
  1. $(function() {});

Récapitulatif

La déclaration des Models, des Views et des Routers Backbonejs doivent être placée dans la fonction anonyme :
  1.  (function($) {} (jQuery)); 
Par contre l’instanciation du router doit être de préférence réalisé dans la fonction :
  1. $(function() {}); 

Thursday, November 8, 2012

Internet Mobile - Septembre 2012

Audience de l'internet Mobile en France - Sept 2012


L'institut Médiamétrie a publié hier ses statistiques concernant l'internet mobile. On y apprend qu'au 3 ème trimestre 2012, 41,2% des individus vivant en France se sont connectés à l'internet mobile par un site ou une application, 46,6% des Français sont équipés d'un smartphone.

Au niveau des systèmes d'exploitation, Android est en forte augmentation par rapport au même trimestre 2011.
En terme de répartition entre les accès via site ou application est stable : 92.1% des mobinautes ont visités un site sur mobile et 72.1% ont visités au moins une application sur smartphone.

Source :  L'audience de l'internet mobile en France en septembre 2012 - Médiamétrie