npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@borane/slick

v5.0.8

Published

Slick est un framework novateur permettant la création de Single Page Applications (SPA) à l'aide de Server Side Rendering (SSR). Conçu pour être rapide, léger et simple d'utilisation, Slick offre une alternative efficace pour le développement d'applicati

Downloads

137

Readme

Présentation

Slick est un framework Typescript pour la création de Single Page Applications en intégrant le Server Side Rendering. Conçu pour être performant, léger et facile à utiliser, Slick propose une alternative aux frameworks tels que React, Angular et Vue. Ces derniers sont généralement moins rapides et plus lourds à exécuter, tandis que Slick vise à offrir une solution plus efficace et légère pour le développement d'applications web.

Technologies

  • Language : Node (Typescript)
  • Librairies : @borane/expressapi, clean-css, terser, mime

Avantages

  • Rapidité et Légèreté: Slick est conçu pour offrir des performances élevées avec un script ne pesant que quelques kilooctets.
  • Support JSX: Profitez de la puissance de la syntaxe JSX pour la création d'interfaces utilisateur.
  • Simplicité d'utilisation: Avec une configuration minimale, Slick facilite le processus de développement.

Installation

Pour commencer un nouveau projet avec Slick, suivez ces étapes après avoir installé NodeJS:

  1. Créez un nouveau répertoire: mkdir Nouveau_Projet && cd Nouveau_Projet.

  2. Mettez en place la structure du projet mkdir src && cd src && mkdir templates pages styles scripts assets && cd ...

  3. Initialisez le projet NodeJS: npm init -y.

  4. Installez Slick: npm i @borane/slick.

  5. Créez et personnalisez les champs name, version, et author du fichier package.json:

{
    "name": "nouveau_projet",
    "version": "1.0.0",
    "author": "username",

    "scripts": {
        "dev": "node ./src/index.js --dev",
        "build": "node ./src/index.js"
    },

    "dependencies": {
        "@borane/slick": "^4.0.0"
    }
}
  1. Lancez le projet avec l'une des commandes suivantes:
  • npm run dev
  • npm run build

Documentation

Fichier d'Initialisation

Slick nécessite un fichier d'initialisation pour démarrer votre application. Créez le fichier src/index.js:

const { Slick } = require("@borane/slick");

new Slick({
    workspace: __dirname,
    port: 5000,

    lang: "en",
    alias: {
        "/favicon.ico": "/assets/favicon.ico",
        "/robots.txt": "/assets/robots.txt"
    },

    redirect404: "/",
    development: false
});

Ce fichier définit les paramètres essentiels pour le fonctionnement de Slick, tels que le répertoire racine, le port, les alias ...

Templates

Les templates dans Slick définissent la structure des pages dans votre application. Chaque template est associé à une page spécifique et contient des informations sur les styles, les scripts, les balises et , ainsi que des fonctions facultatives pour personnaliser le comportement de la page.

return {
    name: "dashboard",

    styles: [
        "/styles/dashboard.css"
    ],
    scripts: [
        "/scripts/dashboard.js"
    ],

    head: <>
        <meta name="robots" content="index, follow" />
    </>,
    body: req => {
        const classname = "url";
        return <>
            <p class={classname}>{req.url}</p>
            <div id="app"></div>
        </>
    },

    onrequest: req => {
        req.url = "/newurl";
    }
};

Propriétés :

  • name: Le nom du template, utilisé pour l'associer aux pages correspondantes. ( String )
  • styles: Tableau des chemins vers les fichiers CSS spécifiques au template. ( Array )
  • scripts: Tableau des chemins vers les fichiers JavaScript spécifiques au template. ( Array )
  • head: Contenu de la balise ( <></> | Async function(req) )
  • body: Contenu de la balise ( <></> | Async function(req) )
  • onrequest: Fonction facultative pour la gestion personnalisée des requêtes HTTP spécifiques au template. ( Async function(req) | Null )

Remarques :

  • Les templates fournissent une structure réutilisable pour les pages, facilitant la gestion de la mise en page globale de l'application.
  • Les styles et scripts spécifiques au template permettent de définir des ressources spécifiques à une mise en page particulière.
  • Le conteneur avec l'identifiant "app" dans la section body est essentiel pour l'insertion correcte du contenu de la page. Assurez-vous de maintenir cet élément avec l'identifiant spécifié.
  • La fonction onrequest offre un contrôle personnalisé sur le traitement des requêtes HTTP spécifiques au template, permettant des actions telles que les redirections en fonction de la logique de votre application grace à req.url.

Pages

Les pages dans Slick définissent le contenu spécifique à afficher pour une URL particulière. Chaque page est associée à un template qui structure la mise en page générale de la page. Voici un exemple de structure de page :

return {
    url: "/",
    template: "dashboard",

    title: "Index",
    favicon: "/favicon.ico",

    styles: [
        "/styles/dashboard/index.css"
    ],
    scripts: [
        "/scripts/dashboard/index.js"
    ],

    head: <>
        <meta name="og:description" content="Index" />
    </>,

    body: req => {
        const text = "This is the content of the page. Method:" + req.method;
        return <>
            <p>{text}</p>
        </>
    },

    onrequest: null
};

Propriétés :

  • url: L'URL associée à la page. ( String )
  • template: Le nom du template à utiliser pour cette page. ( String )
  • title: Titre de la page. ( String )
  • favicon ( Null | String )
  • styles: Tableau des chemins vers les fichiers CSS spécifiques au template. ( Array )
  • scripts: Tableau des chemins vers les fichiers JavaScript spécifiques au template. ( Array )
  • head: Contenu de la balise ( <></> | Async function(req) )
  • body: Contenu de la balise ( <></> | Async function(req) )
  • onrequest: Fonction facultative pour la gestion personnalisée des requêtes HTTP spécifiques au template. ( Async function(req) | Null )

Remarques :

  • Assurez-vous que le template spécifié existe et correspond à celui défini dans le template global de l'application.
  • Les styles et scripts sont spécifiques à chaque page, offrant une modularité pour le chargement de ressources.
  • La fonction onrequest offre un contrôle personnalisé sur le traitement des requêtes HTTP spécifiques au template, permettant des actions telles que les redirections en fonction de la logique de votre application grace à req.url.

User Script

Slick propose un User Script qui vous permet d'interagir avec votre application et de contrôler divers aspects de celle-ci. Cela est particulièrement utile pour gérer des actions telles que le rechargement de la page, la redirection, ou la gestion des cookies directement depuis les fichiers JavaScript de votre site.

Slick

  • redirect(url, reload = false): Redirige l'utilisateur vers l'URL spécifiée.

SlickCookies

  • set(cname, cvalue, exdays = 14): Définit un cookie avec son nom, sa valeur et optionnelement sa date d'expiration.
  • get(name): Récupère la valeur d'un cookie par son nom.
  • delete(cname): Supprime un cookie par son nom.

Disclamer

Slick n'intègre pas directement le JSX de React. Toutefois, il compile les modules, permettant ainsi l'utilisation d'HTML au sein du JavaScript. Il est important de noter que cette fonctionnalité diffère de la prise en charge native du JSX de React et peut ne pas offrir les mêmes avantages ou fonctionnalités.

En tant que framework de développement, Slick est conçu pour allier performance et simplicité d'utilisation. Bien que nous nous efforcions d'offrir une expérience fluide, comme tout logiciel, Slick peut parfois présenter des bugs ou des vulnérabilités. Si vous rencontrez un problème ou si vous avez des préoccupations concernant la sécurité de Slick, nous vous encourageons vivement à nous en informer immédiatement.

Vous aimez Slick ? Ajoutez une star à notre répertoire :star::arrow_up:.