ExpressJS - Sirviendo archivos estáticos

Los archivos estáticos son archivos que los clientes descargan tal como son del servidor. Crea un nuevo directorio,public. Express, de forma predeterminada, no le permite servir archivos estáticos. Debe habilitarlo utilizando el siguiente middleware integrado.

app.use(express.static('public'));

Note - Express busca los archivos relacionados con el directorio estático, por lo que el nombre del directorio estático no es parte de la URL.

Tenga en cuenta que la ruta raíz ahora está configurada en su directorio público, por lo que todos los archivos estáticos que cargue se considerarán públicos como raíz. Para probar que esto funciona bien, agregue cualquier archivo de imagen en su nuevopublic dir y cambie su nombre a "testimage.jpg". En sus vistas, cree una nueva vista e incluya este archivo como:

html
   head
   body
      h3 Testing static file serving:
      img(src = "/testimage.jpg", alt = "Testing Image

Debería obtener el siguiente resultado:

Varios directorios estáticos

También podemos configurar varios directorios de activos estáticos usando el siguiente programa:

var express = require('express');
var app = express();

app.use(express.static('public'));
app.use(express.static('images'));

app.listen(3000);

Prefijo de ruta virtual

También podemos proporcionar un prefijo de ruta para entregar archivos estáticos. Por ejemplo, si desea proporcionar un prefijo de ruta como'/static', debe incluir el siguiente código en su index.js archivo -

var express = require('express');
var app = express();

app.use('/static', express.static('public'));

app.listen(3000);

Ahora, siempre que necesite incluir un archivo, por ejemplo, un archivo de script llamado main.js que reside en su directorio público, use la siguiente etiqueta de script:

<script src = "/static/main.js" />

Esta técnica puede resultar útil cuando se proporcionan varios directorios como archivos estáticos. Estos prefijos pueden ayudar a distinguir entre varios directorios.