Update v4.2 - New components, 10+ framework guides, and quality improvements. Visit Changelog

Install Preline UI with Express.js using Tailwind CSS

Install Preline UI with Tailwind CSS in Express.js projects, including JavaScript plugin setup, static scripts, template rendering, and optional dependencies.

Prerequisites

This guide assumes you already have an Express.js project with Tailwind CSS v4 configured. This guide focuses only on adding Preline UI to your existing setup.

Express.js quick setup

Start with an Express.js application that already has Tailwind CSS configured, then add Preline UI to your existing styles, static files, and templates.

  1. Install Preline UI

    Install preline with your preferred package manager in your Express.js project directory.

    Terminal
    													
    														npm install preline
    													
    												

    Preline UI uses the Tailwind CSS Forms plugin across form components. Install it if you have not already: npm install -D @tailwindcss/forms

  2. Import Preline CSS and source files

    Add the Preline UI CSS variants, source path, and optional theme import to your existing CSS file.

    public/stylesheets/input.css
    													
    														@import "tailwindcss";
    
    														/* Preline UI */
    														@source "./node_modules/preline/dist/*.js";
    														@import "./node_modules/preline/variants.css";
    
    														/* Plugins */
    														@plugin "@tailwindcss/forms";
    
    														/* Preline Themes */
    														@import "./themes/theme.css";
    													
    												

    See the Theme docs to learn more about Preline Themes.

  3. Serve Preline assets with Express

    Update your Express.js app to serve your existing static files and expose the Preline assets you need at runtime.

    app.js
    													
    														const express = require('express');
    														const path = require('path');
    														
    														const app = express();
    														
    														// Serve static files
    														app.use(express.static(path.join(__dirname, 'public')));
    														app.use('/node_modules', express.static(path.join(__dirname, 'node_modules')));
    													
    												
  4. Load Preline UI in Express templates

    Include the Preline JavaScript file in your shared Express template, whether you use Pug, EJS, Handlebars, or another view engine.

    													
    														
    														doctype html
    															html
    																head
    																	title= title
    																	link(rel='stylesheet', href='/stylesheets/main.css')
    																body
    																	block content
    																	script(src='/node_modules/preline/dist/preline.js')
    													
    												

Optional Preline UI styles

Preline UI ships with a small set of opinionated base styles. If you want them in your project, add them to your CSS file. These defaults used to come bundled with Tailwind CSS v3, so they are still available as an optional layer in Preline UI.

CSS
												
													/* Adds pointer cursor to buttons */
													@layer base {
														button:not(:disabled),
														[role="button"]:not(:disabled) {
															cursor: pointer;
														}
													}

													/* Defaults hover styles on all devices */
													@custom-variant hover (&:hover);
												
											

© 2026 Preline Labs.