tail.select - Beautify Select Fields
The tail.select script is back and ready to beautify your (multiple) select fields again, now
also with an own search method and many features to increase the usability and handling on many as
well as on just a few options! It contains all options and features from the original deprecated
jQuery Version, back from 2014 (+ a MooTools implementation)!
Wanna see tail.select in action?
Wanna translate tail.select in your language?
Support
You really like my tail.select script and want to support me and all of my projects?
Then I would be extremely grateful for a coffee! (Thanks to all Supporters)
Features
- Beautiful Single / Multiple Select replacement.
- Search function to find desired options quickly.
- Deselect-able, Limit-able and optional option descriptions.
- Manipulate and Move (selected) options during the runtime.
- Completely Translatable and already available in multiple languages.
- Many Settings to adapt and configure the design and behaviour.
- Supports AMD (requireJS) and available as browserify and ES6 module.
- Compatible with all modern browsers (including IE 10+)
- No Dependencies, just embed and use
- Free/To/Use - MIT Licensed
Install & Embed
The master branch will always contain the latest Release, which you can download directly here
as .tar or as .zip
archive, or just visit the Releases Page
on GitHub directly. You can also be cool and using npm, Yarn or bower:
npm install tail.select --save
yarn add tail.select --save
bower install tail.select --save
Using a CDN
You can also use the awesome CDN services from jsDelivr or UNPKG.
https://cdn.jsdelivr.net/npm/tail.select@latest/
https://unpkg.com/tail.select/
Thanks To
Translations
Documentation
The Documentation has been moved to GitHubs Wiki Pages,
but I will keep a table of contents list here and some basic instructions.
Files
The tail.select
package contains different JavaScript files:
js/tail.select(.min).js
The main JavaScript with en
tranlation strings only.js/tail.select-full(.min).js
The main JavaScript with ALL available translations.js/tail.select-es6(.min).js
An experimental ECMAScript 2015 / ES6 Module version (includes all translations).langs/tail.select-all(.min).js
Just ALL translation strings itself.langs/tail.select-{locale}.js
Just the {locale} translation strings.
Basic Instructions
You can pass up to 2 arguments to the tail.select constructor, the first parameter is required
and need to be an Element
, a NodeList
, a HTMLCollection
, an Array with Element
objects or
just a single selector as string
, which calls the querySelectorAll()
method on its own. The
second parameter is optional and, if set, MUST be an object with your tail.select options.
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<link type="text/css" rel="stylesheet" href="css/tail.select-default.css" />
</head>
<body>
<script type="text/javascript" src="js/tail.select.min.js"></script>
<select>
<option>My Option</option>
</select>
<script type="text/javascript">
document.addEventListener("DOMContentLoaded", function(){
tail.select("select", { });
});
</script>
</body>
</html>
Default options
Please check out GitHubs Wiki Pages to read more
about each single option!
tail.select("select", {
animate: true,
classNames: null,
csvOutput: false,
csvSeparator: ",",
descriptions: false,
deselect: false,
disabled: false,
height: 350,
hideDisabled: false,
hideSelected: false,
items: {},
locale: "en",
lingusticRules: {},
multiple: false,
multiLimit: Infinity,
multiPinSelected: false,
multiContainer: false,
multiShowCount: true,
multiShowLimit: false,
multiSelectAll: false,
multiSelectGroup: true,
openAbove: null,
placeholder: null,
search: false,
searchFocus: true,
searchMarked: true,
searchDisabled: true,
sortItems: false,
sortGroups: false,
sourceBind: false,
sourceHide: true,
startOpen: false,
stayOpen: false,
width: null,
cbComplete: undefined,
cbEmpty: undefined,
cbLoopItem: undefined,
cbLoopGroup: undefined
});
Copyright & License
Published under the MIT-License; Copyright © 2014 - 2019 SamBrishes, pytesNET