Laravel

Un framework qui rend heureux

Voir cette catégorie
Vers le bas
Cours Laravel 6 – CSS et Javascript
Dimanche 20 octobre 2019 22:57

Laravel est un framework PHP consacré à la gestion côté serveur mais on ne peut pas créer une application web sans générer du HTML et pour l'accompagner du CSS et du Javascript. Laravel n'impose rien en la matière mais il privilégie quelques outils : Bootstrap , React, et Vue.js. D'autres part il propose NPM comme installeur.

Un package

Lorsqu'on installe Laravel on ne dispose pas de grand chose côté frontend. Pratiquement rien au niveau CSS et Javascript. On a vu dans le chapitre sur l'authentification qu'il faut installer un package supplémentaire (laravel/ui) pour mettre en place l’infrastructure de base :

composer require laravel/ui --dev
On dispose alors de nouvelles commandes : Dans chapitre de l'authentification on a utilisé la commande :
php artisan ui vue --auth

L'option --auth permet d'ajouter en plus l'intendance pour l'authentification

La seconde solution est d'utiliser la commande :
php artisan ui react --auth
Pour obtenir le même résultat mais avec React plutôt que Vue. Pour la suite je vais prendre Vue. Pour le moment il n'y a pas d'autre preset.

Le CSS avec Laravel Mix

Si vous voulez utiliser un langage de génération de CSS comme Sass (qui connait un grand succès) ou Less alors vous pouvez opter pour Laravel Mix. Il est vrai que ces langages présentent de nombreux avantages par rapport au simple CSS :

  • utilisation de variables
  • imbrication de code
  • importations
  • mixins (groupe de déclaration CSS réutilisable)
  • héritage
  • opérateurs...
On peut très bien se contenter de la console pour générer le CSS à partir par exemple d'un fichier Sass :
sass input.scss output.css
On peut en plus mettre en place un observateur pour régénérer le code.

Mais on peut aussi utiliser Laravel Mix. Sous le capot il utilise Webpack qui n'est pas si simple que ça à utiliser directement. Du coup c'est une façon plus simple d'utiliser Webpack.

Installation

Pour utiliser Laravel Mix vous devez disposer de NPM, donc aussi de node.js. Si vous n'êtes pas trop sûr d'avoir ça sur votre machine entrez ça dans votre console :

node -v
npm -v

Si vous obtenez un numéro de version c'est que vous en disposez mais assurez-vous quand même que ce ne soient pas des versions trop anciennes sinon vous aurez des soucis !

Si vous n'avez rien alors installez-les en suivant les procédures sur les sites correspondants.

Dans l'installation de Laravel vous trouvez déjà un fichier package.json à la racine :

Il comporte toutes les déclarations de scripts et de dépendances nécessaires. Selon vos besoin vous pourrez adapter tout ça, par exemple si vous ne comptez pas utiliser vue.js vous pouvez le retirer de la liste des dépendances.

Pour installer il ne vous reste plus qu'à entrer :
npm install
Là vous avez le temps d'aller boire tranquillement un café... Vous allez avoir la création d'un dossier node_modules contenant toutes les dépendances :

Utilisation

Maintenant vous pouvez utiliser le fichier webpack.mix.js pour préciser ce que vous voulez compiler. Par défaut on a ce code :

const mix = require('laravel-mix');

/*
 |--------------------------------------------------------------------------
 | Mix Asset Management
 |--------------------------------------------------------------------------
 |
 | Mix provides a clean, fluent API for defining some Webpack build steps
 | for your Laravel application. By default, we are compiling the Sass
 | file for the application as well as bundling up all the JS files.
 |
 */

mix.js('resources/js/app.js', 'public/js')
   .sass('resources/sass/app.scss', 'public/css');

On a la méthode sass (on dispose également de less et stylus) et on demande de compiler le fichier resources/sass/app.scss dans public/css. On a effectivement ce fichier ici :

Pour lancer le processus en mode développement on entre :
npm run dev
Ce qui a pour effet de créer (en fait ici régénérer parce qu'il existe déjà) le fichier app.css (et aussi celui du Javascript mais j'en parlerai plus loin) : Le code CSS est en clair puisqu'on est en mode développement :
...

html {
  font-family: sans-serif;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

...
En mode production on utilise :
npm run production

Là on obtient un code minifié pour gagner en dimension de fichier, donc en temps de téléchargement.

Un aspect intéressant est le mode observateur :

npm run watch

Dans ce mode le code est surveillé et la compilation se lance à chaque changement, ce qui est parfait quand on développe.

Le Javascript avec Laravel Mix

Pour le Javascript on peut aussi utiliser Laravel Mix comme on l'a vu ci-dessus pour le CSS. D'ailleurs on a dans le fichier webpack.mix.js une compilation de javascript :

mix.js('resources/js/app.js', 'public/js')

On utilise la méthode js pour compiler le fichier resources/js/app.js dans public/js. On a effectivement ce fichier ici :

Et le résultat compilé va se retrouver ici :

Les commandes sont strictement les mêmes que celles qu'on a vues pour le CSS puisque les opérations sont groupées.

Voyons de plus près le fichier resources/js/app.js :
require('./bootstrap');

window.Vue = require('vue');

Vue.component('example-component', require('./components/ExampleComponent.vue').default);

const app = new Vue({
    el: '#app'
});

On voit qu'on utilise vue.js et qu'on crée le composant example. Le code de ce composant est ici :

Pour information j'ai écrit un petit cours sur vue.js 2 dans ce blog.

Voici le code de ce composant :
<template>
    <div class="container">
        <div class="row justify-content-center">
            <div class="col-md-8">
                <div class="card">
                    <div class="card-header">Example Component</div>

                    <div class="card-body">
                        I'm an example component.
                    </div>
                </div>
            </div>
        </div>
    </div>
</template>

<script>
    export default {
        mounted() {
            console.log('Component mounted.')
        }
    }
</script>

On va s’en servir pour voir si ça fonctionne… Il suffit de créer une vue qui charge le CSS et le JavaScript et qui inclue le composant de Vue.js :

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <link rel="stylesheet" href="{{ asset('css/app.css') }}">
    </head>
    <body>
        <div id="app">
            <example-component></example-component>
        </div>
        <script type="text/javascript" src="{{ asset('js/app.js') }}"></script>
    </body>
</html>
Et voici le résultat :

Comme vous le constatez l’intendance est en place si vous voulez l’utiliser !

Si vous préférez utiliser React alors vous avez utilisé au départ cette commande :

php artisan ui react --auth
Avec React si vous regardez le code du fichier resources/assets/js/app.js :
require('./bootstrap');

require('./components/Example');
C'est maintenant un composant React qui est appelé. Ce composant est ici : Avec ce code :
import React from 'react';
import ReactDOM from 'react-dom';

function Example() {
    return (
        <div className="container">
            <div className="row justify-content-center">
                <div className="col-md-8">
                    <div className="card">
                        <div className="card-header">Example Component</div>

                        <div className="card-body">I'm an example component!</div>
                    </div>
                </div>
            </div>
        </div>
    );
}

export default Example;

if (document.getElementById('example')) {
    ReactDOM.render(<Example />, document.getElementById('example'));
}
Vous pouvez de la même manière tester ce composant.

Les actions de Laravel Mix

Laravel Mix sait faire bien d'autres choses que compiler du CSS ou du Javascript. Par exemple il sait copier des fichiers :
mix.copy('node_modules/foo/bar.css', 'public/css/bar.css');
Copier des dossiers :
mix.copyDirectory('assets/img', 'public/img');
Je vous invite à consulter la documentation officielle pour en apprendre plus.

En résumé

  • Laravel Mix permet de compiler du CSS.
  • Laravel Mix permet de compiler du Javascript.
  • Laravel comporte une intendance pour l'utilisation de Vue ou React.


Par bestmomo

Aucun commentaire