1
0
mirror of synced 2024-11-22 13:06:08 +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 017c201094 More intuitive handling of the enter key
Previously, when in results the enter key would select items that
were highlighted if they were not already selected.  In the case of
a select where multiple items could be selected, pressing enter
when highlighting a selected item would also allow it to be
unselected.  While this seems intuitive for accessibility purposes,
the enter button essentially working as a toggle, it caused some
really strange behavior.

- If the enter button was held down, all previously selected items
  would be unselected.
- The enter button did not work the same across both single and
  multiple selects.

After listening to user feedback, I have decided to remove the
"enter as toggle" functionality from Select2 and have gone back to
just having the enter button select items.  This means that instead
of unselected items that are already selected and highlighted,
Select2 will just close the dropdown.  This is the same as what
Select2 would previously do for single selects, so the keyboard
functionality is now the same across both.

Because this removed the only easy way to unselect items in the
dropdown using the keyboard, we had to maintain the toggle
functionality.  We decided to implement the toggle functionality
on the CTRL + Space keybinding, which is in line with other
applications.  Now when pressing CTRL + Space at the same time in
the dropdown, the highlighted result will behave the same as if the
mouse selected it, which will toggle the current item in multiple
select mode and close the dropdown in single select mode.

This is the same keybinding that Windows Explorer [1] and GTK [2]
use for toggling the current selection, which was why it was picked.

This also fixes an issue where keyboard focus would be lost once an
item was unselected from the results.  This was due to a bug in the
CloseOnSelect module that would only automatically close the
dropdown when an item was selected, but not when an item was
unselected.  Now the dropdown will be closed automatically when an
item is unselected, which will also cause the selection (and
eventually the search) to be focused.

This fixes two issues described in
https://github.com/select2/select2/issues/3036#issuecomment-76321411.

[1]: http://superuser.com/q/78891/72528
[2]: https://developer.gnome.org/gtk3/stable/GtkIconView.html#GtkIconView-toggle-cursor-item
2015-03-01 20:30:43 -05:00
dist More intuitive handling of the enter key 2015-03-01 20:30:43 -05:00
docs Added example for hiding search 2015-02-27 20:37:48 -05:00
src More intuitive handling of the enter key 2015-03-01 20:30:43 -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.