Embed EmojiFYI widgets — emojis, glossary terms, interactive tools, and inline elements — on any website. 9 widget types, zero dependencies, Shadow DOM style isolation, 4 built-in themes (light, dark, sepia, auto), 2 styles (modern, minimal), and live data from the EmojiFYI database.
Every widget includes a "Powered by EmojiFYI" backlink directing readers to the full reference.
Try the interactive widget builder at widget.emojifyi.com
<!-- Place widget div where you want it to appear -->
<div data-emojifyi="entity" data-slug="emojis" data-theme="light"></div>
<!-- Load the embed script once, anywhere on the page -->
<script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script>That's it. The widget fetches data from the EmojiFYI API and renders with full style isolation.
| Type | Usage | Description |
|---|---|---|
entity |
<div data-emojifyi="entity" data-slug="..."></div> |
Entity detail card — color, font, emoji, symbol, or character |
glossary |
<div data-emojifyi="glossary" data-slug="..."></div> |
Glossary term definition with cross-references |
guide |
<div data-emojifyi="guide" data-slug="..."></div> |
Guide summary card with key takeaways |
compare |
<div data-emojifyi="compare" data-slug="..."></div> |
Side-by-side entity comparison |
search |
<div data-emojifyi="search" data-slug="..."></div> |
Search box linking to the full database |
encoder |
<div data-emojifyi="encoder" data-slug="..."></div> |
Emoji encoder — 8 formats (UTF-8, HTML, CSS, JS, Python, Java) |
picker |
<div data-emojifyi="picker" data-slug="..."></div> |
Emoji picker grid — searchable by category |
emoji-inline |
<div data-emojifyi="emoji-inline" data-slug="..."></div> |
Inline emoji with name and codepoint |
tooltip |
<div data-emojifyi="tooltip" data-slug="..."></div> |
Glossary tooltip — hover/click shows term definition inline |
| Attribute | Values | Default | Description |
|---|---|---|---|
data-emojifyi |
entity, compare, glossary, guide, search, tooltip, [tools] | required | Widget type |
data-slug |
e.g. "emojis" | — | Entity slug from the EmojiFYI database |
data-theme |
light, dark, sepia, auto | light | Visual theme (auto follows OS preference) |
data-style |
modern, minimal | modern | Widget design style |
data-size |
default, compact, large | default | Widget size |
data-placeholder |
any string | "Search Emojis..." | Search box placeholder |
<!-- Light (default) -->
<div data-emojifyi="entity" data-slug="emojis" data-theme="light"></div>
<!-- Dark -->
<div data-emojifyi="entity" data-slug="emojis" data-theme="dark"></div>
<!-- Sepia -->
<div data-emojifyi="entity" data-slug="emojis" data-theme="sepia"></div>
<!-- Auto — follows OS dark/light preference -->
<div data-emojifyi="entity" data-slug="emojis" data-theme="auto"></div><!-- Modern (default) — clean lines, rounded corners, accent gradients -->
<div data-emojifyi="entity" data-slug="emojis" data-style="modern"></div>
<!-- Minimal — subtle borders, flat design, no gradients -->
<div data-emojifyi="entity" data-slug="emojis" data-style="minimal"></div>As an alternative to data-* attributes, you can use native HTML custom elements:
<!-- Custom element form -->
<emojifyi-entity slug="emojis" theme="light"></emojifyi-entity>
<emojifyi-compare slugs="emojis,other-slug"></emojifyi-compare>
<emojifyi-search placeholder="Search Emojis..."></emojifyi-search>
<script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script>Use style-variant (not style) to avoid conflicts with the HTML reserved style attribute.
<div data-emojifyi="entity" data-slug="emojis" data-theme="light"></div>
<script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script><div data-emojifyi="compare" data-slugs="emojis,other-slug"></div>
<script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script><div data-emojifyi="search" data-placeholder="Search Emojis..."></div>
<script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script><div data-emojifyi="glossary" data-slug="example-term" data-theme="light"></div>
<script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script><script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1/dist/embed.min.js"></script><script src="https://cdn.jsdelivr.net/npm/emojifyi-embed@1.0.0/dist/embed.min.js"></script>npm install emojifyi-embedimport 'emojifyi-embed';- Shadow DOM: Complete style isolation — no CSS conflicts with your site
- Zero dependencies: No jQuery, React, or any external library
- 2 styles: Modern (accent gradients) and Minimal (flat design)
- 4 themes: Light, Dark, Sepia, Auto (OS preference detection)
- CORS: EmojiFYI API has CORS enabled for all origins
- MutationObserver: Works with dynamically added elements (SPAs)
- IntersectionObserver: Lazy loading — widgets only fetch when entering viewport (200px margin)
- Rich Snippets: DefinedTerm JSON-LD injected for glossary widgets
- Bundle size: ~11-21KB gzipped (per-site build — only includes tools available on EmojiFYI)
Visit emojifyi.com — EmojiFYI is a comprehensive emojis reference with interactive tools, guides, and developer resources.
- API docs: emojifyi.com/developers/
- Widget builder: widget.emojifyi.com
- npm package: npmjs.com/package/emojifyi-embed
- GitHub: github.com/fyipedia/emojifyi-embed
Part of FYIPedia — open-source developer tools ecosystem. Creative FYI covers design, typography, characters, and visual encoding.
| Site | Domain | Focus | Package |
|---|---|---|---|
| ColorFYI | colorfyi.com | Color conversion, WCAG contrast, harmonies — 16.7M hex colors | npm |
| FontFYI | fontfyi.com | Google Fonts metadata, CSS generation, font pairings | npm |
| EmojiFYI | emojifyi.com | 3,781 emojis, Unicode Emoji 16.0, 8 encodings | npm |
| SymbolFYI | symbolfyi.com | Symbol encoding in 11 formats, Unicode properties | npm |
| UnicodeFYI | unicodefyi.com | Unicode characters, 17 encodings, text analysis | npm |
MIT — see LICENSE.
Built with care by FYIPedia.