Research
Security News
Threat Actor Exposes Playbook for Exploiting npm to Build Blockchain-Powered Botnets
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
MJML is a markup language designed to reduce the pain of coding responsive emails. It abstracts away the complexity of responsive design by providing a simple syntax that translates into responsive HTML.
Responsive Email Design
MJML allows you to create responsive email designs easily. The above code creates a simple responsive email with a 'Hello World' text.
<mjml>
<mj-body>
<mj-section>
<mj-column>
<mj-text>Hello World</mj-text>
</mj-column>
</mj-section>
</mj-body>
</mjml>
Custom Components
MJML provides a variety of built-in components like buttons, images, and text blocks. The above code demonstrates how to create a button that links to a URL.
<mjml>
<mj-body>
<mj-section>
<mj-column>
<mj-button href="https://www.example.com">Click Me</mj-button>
</mj-column>
</mj-section>
</mj-body>
</mjml>
Conditional Rendering
MJML supports conditional rendering for different email clients. The above code shows how to include content specifically for Microsoft Outlook.
<mjml>
<mj-body>
<mj-raw>
<!--[if mso]>
<mj-section>
<mj-column>
<mj-text>Microsoft Outlook specific content</mj-text>
</mj-column>
</mj-section>
<![endif]-->
</mj-raw>
</mj-body>
</mjml>
Handlebars is a popular templating engine that can be used to create dynamic HTML content, including emails. Unlike MJML, Handlebars does not provide built-in responsive design features, so you would need to handle the CSS and media queries yourself.
Pug (formerly Jade) is another templating engine that can be used to generate HTML. While it is powerful and flexible, it does not offer the same level of abstraction for responsive email design as MJML does.
Nunjucks is a templating engine inspired by Jinja2. It is highly extensible and can be used to generate HTML for emails. However, like Handlebars and Pug, it does not provide built-in support for responsive email design.
| Introduction | Installation | Usage | Contribute |
MJML is a markup language designed to reduce the pain of coding a responsive email. Its semantic syntax makes it easy and straightforward while its rich standard components library fastens your development time and lightens your email codebase. MJML’s open-source engine takes care of translating the MJML you wrote into responsive HTML.
We recommend installing and using MJML locally, in a project folder where you'll use MJML:
$> npm install mjml
In the folder where you installed MJML you can now run:
$> ./node_modules/.bin/mjml input.mjml
To avoid typing ./node_modules/.bin/
, add it to your PATH:
$> export PATH="$PATH:./node_modules/.bin"
You can now run MJML directly, in that folder:
$> mjml input.mjml
Via... click:
Compiles the file and outputs the HTML generated in
input.html
$> mjml -r input.mjml
Redirects the HTML generated to a file named output.html
$> mjml -r input.mjml -o output.html
Sets the validation rule to
skip
so that the file is rendered without being validated
$> mjml -l skip -r input.mjml
Watches a file and compiles every time the file changes
$> mjml -w input.mjml -o output.html
import { mjml2html } from 'mjml'
/*
Compile an mjml string
*/
const htmlOutput = mjml2html(`
<mjml>
<mj-body>
<mj-container>
<mj-section>
<mj-column>
<mj-text>
Hello World!
</mj-text>
</mj-column>
</mj-section>
</mj-container>
</mj-body>
</mjml>
`)
/*
Print the responsive HTML generated and MJML errors if any
*/
console.log(htmlOutput)
One of the great advantages of MJML is that it's component based. Components abstract complex patterns and can easily be reused. Added to the standard library of components, it is also possible to create your own components!
To learn how to create your own component, follow this step-by-step guide which also includes a ready-to-use boilerplate.
Get your hands dirty by trying the MJML online editor! Write awesome code on the left side and preview your email on the right. You can also get the rendered HTML directly from the online editor.
Maxime | Robin | Loeck | Guillaume | Meriadec | Nicolas | Arnaud | HTeuMeuLeu | Emmanuel Payet | Matthieu |
FAQs
MJML: the only framework that makes responsive-email easy
The npm package mjml receives a total of 417,881 weekly downloads. As such, mjml popularity was classified as popular.
We found that mjml demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
Security News
NVD’s backlog surpasses 20,000 CVEs as analysis slows and NIST announces new system updates to address ongoing delays.
Security News
Research
A malicious npm package disguised as a WhatsApp client is exploiting authentication flows with a remote kill switch to exfiltrate data and destroy files.