Piste :
Différences ¶
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédenteProchaine révisionLes deux révisions suivantes | ||
presentation [2006/10/17 20:08] – (old revision restored) 127.0.0.1 | presentation [2008/06/08 20:52] – édition externe 127.0.0.1 | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
====== Présentation de Jelix ====== | ====== Présentation de Jelix ====== | ||
+ | |||
===== Généralités ===== | ===== Généralités ===== | ||
- | Jelix est un framework pour PHP5, dont l' | + | Jelix est un framework pour PHP5 qui aide les développeurs |
- | Il propose | + | Il propose : |
- | * un ensemble d'API qui prend en charge nombre d' | + | * un ensemble d'API qui prend en charge nombre d' |
* une structure modulaire et une organisation des fichiers du projet, imposant donc un cadre et des normes de développement. | * une structure modulaire et une organisation des fichiers du projet, imposant donc un cadre et des normes de développement. | ||
- | * un découpage "en couche" | + | * Une cinématique MVC (Model, View, Controller), |
Ces caractéristiques permettent une meilleure réutilisation du code, une capitalisation du savoir-faire, | Ces caractéristiques permettent une meilleure réutilisation du code, une capitalisation du savoir-faire, | ||
- | Jelix utilise au maximum les spécificités de PHP5, afin d' | + | Jelix utilise au maximum les spécificités de PHP 5.2, afin d' |
===== Fonctionnalités proposées ===== | ===== Fonctionnalités proposées ===== | ||
Ligne 21: | Ligne 22: | ||
* **Architecture modulaire** : une application peut être découpée en plusieurs modules réutilisables. | * **Architecture modulaire** : une application peut être découpée en plusieurs modules réutilisables. | ||
- | * **Garantie minimale sur l' | + | * **Garantie minimale sur l' |
- | * **génération | + | * **Génération |
- | * **Moteur de template léger et évolutif** (jTpl), avec pour les templates une syntaxe à mi-chemin entre Smarty et PHP. Un système de plugin à la Smarty est également disponible. | + | * **jDAO, mapping objet-relationnel** reposant sur le design pattern DAO (Data Access Object), se basant sur des fichiers déclaratifs en XML et prenant en charge la génération automatique des requêtes SQL, des problématiques de sécurité (SQL injection etc...). jDao génère |
- | * **jDAO, mapping objet-relationnel** reposant sur le design pattern DAO (Data Access Object), se basant sur des fichiers déclaratifs en XML et prenant en charge la génération automatique des requêtes SQL, des problématiques de sécurité (SQL injection etc...) | + | * **jForms, générateur |
- | * **Désignation | + | |
- | * **Système évènementiel**, permettant la communication inter-module. | + | |
- | * **Surcharge | + | |
- | ==== Fonctions | + | * **Moteur de template très léger, performant |
+ | * **Système événementiel**, | ||
+ | * **Surcharge de fichier** : il est possible de redéfinir certains fichiers d'un module sans toucher aux originaux (daos, templates, locales, formulaires). Cela permet de partager un même module par plusieurs applications, | ||
+ | * **Déclarations de zones de pages** : la construction d'une page web peut se " | ||
+ | * **Désignation des fichiers et ressources par des sélecteurs**, | ||
- | Fonctions | + | ==== Fonctions |
+ | Fonctions que l'on retrouve dans les frameworks récents. | ||
- | * **Services Web** : Jelix prend en charge l' | + | * **Services Web** : Jelix prend en charge l' |
* **Prise en charge de RESTfull** : par simple implémentation d'une interface, on peut définir facilement les traitements suites aux requetes HTTP GET/ | * **Prise en charge de RESTfull** : par simple implémentation d'une interface, on peut définir facilement les traitements suites aux requetes HTTP GET/ | ||
* **Système de thèmes** : il est possible de définir plusieurs thèmes, chacun redéfinissant les templates des modules. | * **Système de thèmes** : il est possible de définir plusieurs thèmes, chacun redéfinissant les templates des modules. | ||
* **Système de génération automatique et de mapping d' | * **Système de génération automatique et de mapping d' | ||
- | * **Des scripts PHP de génération de code** à exécuter en ligne de commande, permettant la création rapide des divers fichiers d'un projet (module, dao, template, | + | * **CRUD générique** : Jelix propose un contrôleur générique permettant de faire une interface d' |
+ | * **Des scripts PHP de génération de code** à exécuter en ligne de commande, permettant la création rapide des divers fichiers d'un projet (module, dao, template, | ||
* **Système de cache technique** : quasiment tous les fichiers non PHP d'un projet Jelix sont " | * **Système de cache technique** : quasiment tous les fichiers non PHP d'un projet Jelix sont " | ||
+ | * **Compatible UTF-8**. C'est d' | ||
+ | * **Module dédié aux tests unitaires** : les tests unitaires sont essentiels pour créer une application qui soit fiable. Jelix propose donc un module qui fourni une interface pour lancer les tests unitaires et un moyen simple de créer des tests unitaires (reposant sur SimpleTest) | ||
+ | |||
==== Fonctions et caractéristiques classiques ==== | ==== Fonctions et caractéristiques classiques ==== | ||
Ligne 45: | Ligne 52: | ||
Fonctions que l'on retrouve dans beaucoup de frameworks | Fonctions que l'on retrouve dans beaucoup de frameworks | ||
- | | + | * **L'architecture du coeur est du type MVC** (Model-View-Controller). Un coordinateur se charge de lancer l' |
+ | * Jelix propose **différents générateurs de format** (les objets jResponse) : XHTML, CSS, ATOM, RSS, XML, RDF, XUL, overlay XUL, ZIP, PDF (à partir de fichiers en Latex ou via TCPDF). D' | ||
* **Couche d' | * **Couche d' | ||
- | * **Localisation** : stockage des messages localisés | + | * **Localisation** : il est possible d' |
* **Système d' | * **Système d' | ||
- | * Utilisation du XML : déclaration des évènements, | + | * Utilisation du XML : déclaration des évènements, |
+ | |||
+ | ===== Principe de fonctionnement ===== | ||
+ | |||
+ | {{http:// | ||
+ | |||
+ | - Jelix reçoit une requête HTTP. Il instancie un objet jRequest qui contient les données de la requête, et instancie le contrôleur qui correspond à l' | ||
+ | - La méthode du contrôleur correspondante à l' | ||
+ | - Le contrôleur exécute les traitements métiers et récupère éventuellement des résultats qui seront utilisés pour l' | ||
+ | - Le contrôleur instancie un objet de type jResponse auquel il assignera les données à afficher, initialisera les templates etc. | ||
+ | - Jelix récupère cet objet jResponse, invoque la génération du document en sortie et envoi ce dernier au navigateur. | ||
===== Une première application ===== | ===== Une première application ===== | ||
- | Lire [[manuel: | + | Lire [[tutoriels: |