1
0
mirror of synced 2024-11-25 14:26:03 +03:00
Select2 is a jQuery based replacement for select boxes. It supports searching, remote data sets, and infinite scrolling of results.
Go to file
Kevin Brown c0839b4f93 Fix searching in Firefox for Android
This fixes an issue where most keys would not trigger the search
in Firefox for Android.  There were only a few keys which would
trigger `keyup`, such as space and enter (the search icon), but
they were not consistent.  We know that they were being triggered
though, as you could type "new " (note the space) and it would
trigger a search, giving us all states that started with "new".

The problem is that Firefox for Android does not consistently
trigger `keyup` and `keydown` events when a keyboard is used.  To
work around the issue, we are now using the `input` event in
replacement of the `keyup` event, which was used to trigger the
search.  While this is not an actual `KeyboardEvent` in Chrome, and
lacks some of the important metadata such as `which`/`key` in
Firefox, it works for our implementation.

As the `input` event is not supported in older browsers, such as
those before Internet Explorer 9, we have to listen for both the
old `keyup` event and the new `input` event.  As the `input` event
is always triggered before the `keyup` event, we unbind the `keyup`
event automatically to prevent searches from being triggered twice.
This solution was discovered in a blog post by Mathias Bynens at
https://mathiasbynens.be/notes/oninput.

**Note:** The ability to backspace in a blank text field on multiple
selects in order to remove the last selected item does not work in
Firefox for Android because the `keydown` event does not trigger
when the text field is empty.  Users can still use the "x" icon
provided at the start of every selected option to achieve the same
effect.

This closes https://github.com/select2/select2/issues/2997.
2015-03-01 19:41:27 -05:00
dist Fix searching in Firefox for Android 2015-03-01 19:41:27 -05:00
docs Added example for hiding search 2015-02-27 20:37:48 -05:00
src Fix searching in Firefox for Android 2015-03-01 19:41:27 -05:00
tests Fixed data-ajax-url fallback 2015-02-27 20:11:13 -05:00
vendor Added jQuery.mousewheel support 2015-01-02 20:32:14 -05:00
.editorconfig Working on rendering everything 2014-10-21 21:43:56 -04:00
.gitignore Start working on translations 2014-10-31 22:24:59 -04:00
.jshintignore Fix undefined variables 2015-02-13 22:49:54 -05:00
.jshintrc Fix undefined variables 2015-02-13 22:49:54 -05:00
.travis.yml Hook up with SauceLabs 2015-02-13 21:59:09 -05:00
bower.json Remove jQuery from the bower and component files 2015-01-27 18:31:52 -05:00
component.json Preparing for the 4.0.0-beta.3 release 2015-01-27 20:11:38 -05:00
composer.json Remove jQuery from the bower and component files 2015-01-27 18:31:52 -05:00
CONTRIBUTING.md Updated README and CONTRIBUTING 2015-01-09 19:26:59 -05:00
Gruntfile.js Added compatibility with <input /> tags 2015-02-27 18:36:34 -05:00
LICENSE.md Updated README and CONTRIBUTING 2015-01-09 19:26:59 -05:00
package.json Hook up with SauceLabs 2015-02-13 21:59:09 -05:00
README.md Updated README and CONTRIBUTING 2015-01-09 19:26:59 -05:00
select2.jquery.json Preparing for the 4.0.0-beta.3 release 2015-01-27 20:11:38 -05:00

Select2

Build Status

Select2 is a jQuery-based replacement for select boxes. It supports searching, remote data sets, and pagination of results.

To get started, checkout examples and documentation at https://select2.github.io/

Use cases

  • Enhancing native selects with search.
  • Enhancing native selects with a better multi-select interface.
  • Loading data from JavaScript: easily load items via AJAX and have them searchable.
  • Nesting optgroups: native selects only support one level of nesting. Select2 does not have this restriction.
  • Tagging: ability to add new items on the fly.
  • Working with large, remote datasets: ability to partially load a dataset based on the search term.
  • Paging of large datasets: easy support for loading more pages when the results are scrolled to the end.
  • Templating: support for custom rendering of results and selections.

Browser compatibility

  • IE 8+
  • Chrome 8+
  • Firefox 10+
  • Safari 3+
  • Opera 10.6+

Usage

You can source Select2 directly from a CDN like JSDliver or CDNJS, download it from this GitHub repo, or use one of the integrations below.

Integrations

Internationalization (i18n)

Select2 supports multiple languages by simply including the right language JS file (dist/js/i18n/it.js, dist/js/i18n/nl.js, etc.) after dist/js/select2.js.

Missing a language? Just copy src/js/select2/i18n/en.js, translate it, and make a pull request back to Select2 here on GitHub.

Documentation

The documentation for Select2 is available through GitHub Pages and is located within this repository in the docs folder.

Community

You can find out about the different ways to get in touch with the Select2 community at the Select2 community page.

The license is available within the repository in the LICENSE file.