Articles by Victoria

Introduction to Bulma: A Simple and Intuitive CSS Framework

Jan 1, 20205 min read
cover

Introduction to Bulma: A Simple and Intuitive CSS Framework

According to its official website, Bulma is a free, open source framework that provides ready-to-use frontend components that you can easily combine to build responsive web interfaces.

In this article, let's take a look at the basics of Bulma and how to build a simple To-Do App using this CSS framework.

Why Use Bulma


Bulma adopts a mobile-first approach, which ensures that UI components would be responsive and looks great in small screens.

It is, at its core, a CSS framework similar to Tailwind CSS and Material UI, so it provides many pre-styled components without JavaScript included. Hence, according to its GitHub documentation, Bulma is "environment agnostic", as it's just the style layer on top of the logic. With Bulma, you can simply focus on the styles.

Bulma is very easy to install and learn. It has intuitive, readable modifiers, syntax and classes.

Getting Started


The 2 ways I recommend to use Bulma in your projects are:

1. Via npm or yarn


npm install bulma

yarn add bulma

2. Via CDN


Starter Template


On Bulma's website, we can also copy the starter HTML template below to our project. As you can see, the starter template imports Bulma via CDN.






Hello Bulma!






Hello World



My first website with Bulma!







If we open this HTML template, we get the following webpage:
image.png

Layout/Spacing


As seen in the starter template, the most common layouts are the .container and .section classes. Using these classes would automatically provide some default margins or padding.

Use the spacing helpers to customize margin and paddings.


Modifier Syntax

Font Sizes Example


In Bulma, the modifier syntax is pretty straightforward. They are often in the is- or the has- format. For example, to adjust font sizes, we use is-size-[number] or is-[number].

Title 1


Subtitle 3

Title 2


Subtitle 4

Title 3


Subtitle 5


image.png


Font Styles Example


For font styles, it is simply is-[style].

Hello World


Hello World


Hello World


Hello World


Hello World


image.png

More details can be found in the documentation.

Text Colors Examples


With changing the text colors, Bulma contains the common classes you will find in other CSS libraries such info, primary, success and so on. The modifier syntax will be has-text-[style].

Hello World


Hello World


Hello World


Hello World


Hello World


Hello World


Hello World



image.png

More details can be found in the documentation.

A Simple To-Do App via Bulma


Now that we've learned the basics of Bulma, let's create a simple to-do app. I will be using the Panel component and start from there.

Step 1: Import Bulma


First, let's import Bulma via CDN into our html file.






Bulma To-Do App






Step 2: Add the components


Inside body, I will add the following:



Bulma To-Do List






As seen in the code above, it is pretty intuitive and easy to understand, even if you're unfamiliar with Bulma. Simply refer to its documentation for the Panel component to understand it. We should now have a nice-looking and simple to-do list.

image.png

### Step 3: Add index.js
Create a file called index.js so we can add items to this list. In this script, we will add a click eventListener to our button and insert a new panel-block component with the value of the user's input. Finally, we will clear the text input after the component is added.

const btn = document.querySelector(".button");
const input = document.querySelector(".input");
const panel = document.querySelector(".panel");

btn.addEventListener("click", function() {
//check if input is empty
if (input.value === "") {
return alert("Please enter a value");
}
//add a new item to the list
const htmlStr =
${input.value}
;
//insert htmlStr in panel
panel.insertAdjacentHTML("beforeend", htmlStr);
//clear input
input.value = "";
});

Result


And here's the result of our simple to-do app!
bulma.gif

Open Source Session Replay


_Debugging a web application in production may be challenging and time-consuming. OpenReplay is an Open-source alternative to FullStory, LogRocket and Hotjar. It allows you to monitor and replay everything your users do and shows how your app behaves for every issue. It’s like having your browser’s inspector open while looking over your user’s shoulder. OpenReplay is the only open-source alternative currently available._

replayer.png

_Happy debugging, for modern frontend teams - Start monitoring your web app for free._

Conclusion


Bulma offers a quick and simple solution for front-end developers. It offers a highly flexible, responsive and intuitive CSS library.

There are also many ways to customize the styles, which are documented in detail here. Thanks for reading the article. I hope it has been helpful in getting you started with Bulma. Cheers!

----------

References


- https://github.com/jgthms/bulma
- https://bulma.io/

Share:

More Articles