Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

datalist-polyfill

Package Overview
Dependencies
Maintainers
1
Versions
64
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

datalist-polyfill

A lightweight and dependency-free vanilla JavaScript datalist polyfill.

  • 1.14.3
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
3.7K
increased by34.21%
Maintainers
1
Weekly downloads
 
Created
Source

datalist-polyfill

datalist-polyfill on Npmjs Total downloads ~ Npmjs jsDelivr CDN downloads dependencies Status

This is a minimal and dependency-free vanilla JavaScript polyfill for the awesome datalist-functionality, that will bring joy and happiness into our lives :-)

  • Mainly built for Safari, as nearly all of the other browsers support it quite well: https://caniuse.com/#feat=datalist
  • Released under the MIT license
  • Made in Germany. And supported by so many great people from all over this planet - see "Credits" accordingly.

Features

  • Lightweight: 5.96 kB of minified JavaScript, around 2.58 kB gzipped
  • Fully flexible to change the datalist entries / <option>s
  • Supporting:
    • the relevant input field types: text, email, number, search, tel and url ...
    • ... while leaving the others like color or date related, as those would most likely need another polyfill to work correctly or have a meaningful UI
    • input[type=email] elements multiple attribute
    • properties .options for datalist elements and .list for input elements
    • right to left text-direction
    • non-touch and touch interactions
    • different types of option declarations
    • both Safari and Internet Explorer (IE9+) browsers
    • controlling the display of differing value and label values
  • Emits "input" event when item in the datalist is selected
  • Enables core keyboard controls such as the up and down arrow keys, ESC, and ENTER
  • Implements the WAI-ARIA design pattern

Core concepts

The plugin was designed with the following concepts kept in mind:

  • dependency-free
  • Supporting DOM changes by event delegation and MutationObserver
  • code accessibility / readability

Installation

Just integrate the JavaScript file into your code - et voilà.

You may optionally load via NPM or Bower:

$ npm install datalist-polyfill
$ bower install datalist-polyfill

API

Nothing really, just plug it in, it will work out of the box.

This package is also enabling the .options (for datalist elements) and .list (for input elements) properties according to the specs.

If you set a title-Attribute on the <datalist> HTML tag, it would get used as label for the first disabled entry within the polyfilling select on non-touch interactions.

dynamic HTML (or DHTML, if you like to be a little bit nostalgic)

In case that you'd like to dynamically add or modify / create your HTML code, you're good to go with this polyfill, as it's based on event delegation and additionally using MutationObserver (IE11+) that makes your UI work easily - no refresh nor reinit function to call after DOM manipulation or something similar.

Changes to the available option elements

If you'd like to make a change to the integrated list of <option> elements, feel free to either remove or add them right away - the list would get generated on the fly after the user typed in something into the <input> field, so you're covered on this.

You can also disable <option> elements by adding the disabled attribute to the <option> HTML tag if necessary.

Differing value and label values

As the browser vendors (Google Chrome vs. the others) don't seem to be aligned on this topic, I've decided to enable the label-attribute to serve as the definitive label being displayed, even if a value is being defined differing from the label. On different value and text values, both of them would get displayed within the suggestions, as Google Chrome does it. But if you define a differing label-attribute, its value would get displayed exclusively (as all the other browsers do it) to give you some flexibility on how to define those suggestions. Check out the „Different ways of defining an option“ section on the demo page regarding this topic.

Microsoft Internet Explorer

Internet Explorer 10-

You'll need the declaration for the standard hidden attribute, that you might already have included in case you're using normalize.css. Otherwise just adapt it from there:

/**
 * Add the correct
 * display in IE 10-
 */

[hidden] {
  display: none;
}
Internet Explorer 9

In case you'd like to support IE9, you'll need to add a nesting select element wrapped by a conditional comment into the datalist element. Please have a look at the demo page accordingly, the code is being mentioned within the Internet Explorer 9 support section.

Demo

See the polyfill in action either by downloading / forking this repo and have a look at demo.html, or at the hosted demo: https://mfranzke.github.io/datalist-polyfill/demo.html

things to keep in mind

  • The demo HTML code is meant to be simple - I do know that things like a surrounding <form> are missing, and I've left the latin letters and english expressions for the right to left text-direction example. But lets focus on the relevant tags that this polyfill is all about for the demo.
  • iOS Safari handles the label-attribute different from Safari on Mac OS. This is being equalized during the handling of the label-attributes-value for differing value and label values.
  • After I thought it through and did some experiments, I've finally chosen the <select> element to polyfill the <datalist>, as it brought most of the functionality, whereas I accepted that it doesn't behave and doesn't look equally.
    • As I wanted to mainly focus on native elements in the most low level / simple way instead of visually emulating a list and than afterwards regain all of the functionality via a lot of JavaScript logic, I've ended up with this element, that knows how to play nicely with nested <option> elements.
    • I tried its multiple attribute, as this is most likely already what you're up to regarding appearance, but it does violate the form-follows-function concept and results in - surprise - the possibility for multiple selections, which isn't always <datalist> elements kind of thing... Then the size attribute came to my attention, which much better fits the requirements and behaves as designed quite perfectly.

Credits

Supported by Christian, Johannes, @mitchhentges, @mertenhanisch, @ailintom, @Kravimir, @mischah, @hryamzik, @ottoville, @IceCreamYou, @wlekin, @eddr and @beebee1987. Thank you very much for that, highly appreciated !

Tested with

  • Mac
    • Mac OSX 10.12, Safari 10
    • Mac OSX 10.11, Safari 9
    • Mac OSX 10.10, Safari 8
    • Mac OSX 10.9, Safari 7
    • Mac OSX 10.8, Safari 6.2
    • Mac OSX 10.7, Safari 6
  • iOS
    • iPad Pro / 10.2, Mobile Safari 10.0
    • iPhone 6 Plus / 10.3, Mobile Safari 10.0
  • Windows
    • Windows 7 SP1, Internet Explorer 9.0.8112.16421

Outro

Personally I even also do like the "keep it simple" approach provided within the W3C specs even already.

But on the other hand this leads to an additional visible field, but doesn't emulate the (hopefully, fingers crossed) upcoming x-browser implementation and leaves unnecessary syntax for all of the clients that wouldn't even need it (anymore).

If you're trying out and using my work, feel free to contact me and give me any feedback. I'm curious about how it's gonna be used.

Keywords

FAQs

Package last updated on 20 Jun 2018

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc