1
0
mirror of synced 2024-11-24 22:06:07 +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 1f3eceba5a
Fix generated options not receiving result IDs (#5586)
In order to enable the ability to uniquely identify a result by an ID
in the DOM, we generate a new ID for the result based on a combination
of things, including the container ID prefix that is generated and
used elsewhere in Select2. This has worked fairly well for use cases
including attaching Select2 to an existing `<select>` and loading in
options from a remote data set.

Unfortunately, because this process relied on the container ID being
used as a prefix, this failed for options which were automatically
generated on initialization using the `data:` option to Select2.
These were not being generated with an ID because at the time that
they were being generated, the data adapter was not aware of the
container it was being used in. This broke some accessibility features
because we had a mix of options in the results list with IDs, and
some without, so we fixed the ordering to make this work.

Option generation no longer happens when the data adapter is first
initialized, which is where it was previously happening, and instead
it now occurs when the data adapter is bound to the container. This
allows us to ensure that the data adapter is always aware of the
container it is being associated with, so now it will be able to
generate the result IDs.

This also fixes the tests for the array adapter as well as the
legacy `<input />` adapter so they properly bind to a container
during the test. This was causing test failures becuase the options
which would previously be generated during initialization were no
longer appearing.

Fixes #4350
2019-07-27 16:37:57 -04:00
.github Enable the Stale integration 2019-03-12 22:07:42 -04:00
dist Recompile dist for 4.0.8 2019-07-20 23:05:45 -04:00
docs update README for /docs 2017-09-10 17:57:07 -04:00
src Fix generated options not receiving result IDs (#5586) 2019-07-27 16:37:57 -04:00
tests Fix generated options not receiving result IDs (#5586) 2019-07-27 16:37:57 -04:00
.editorconfig Working on rendering everything 2014-10-21 21:43:56 -04:00
.gitignore gitignore .sass-cache. 2015-04-28 01:35:14 +02:00
.jshintignore Overhaul of the AMD integration 2015-03-14 19:05:24 -04:00
.jshintrc Migrate from expect to assert.expect 2016-05-23 23:38:45 -04:00
.travis.yml Update dev dependencies (#5529) 2019-06-04 21:18:37 -04:00
bower.json Add license to bower.json 2016-11-03 11:23:50 +01:00
CHANGELOG.md Update changelog for 4.0.8 2019-07-20 23:09:14 -04:00
component.json Bump versions for 4.0.8 release 2019-07-20 23:02:46 -04:00
composer.json Update composer to remove deprecated dependency (#5165) 2019-03-18 22:36:26 -04:00
Gruntfile.js Update dev dependencies (#5529) 2019-06-04 21:18:37 -04:00
LICENSE.md update version in package manager config files 2017-09-06 17:05:28 -04:00
package.json Bump versions for 4.0.8 release 2019-07-20 23:02:46 -04:00
README.md Clean up docs (#5528) 2019-06-04 20:46:45 -04:00

Select2

Build Status cdnjs jsdelivr

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.org/

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

Third party developers have created plugins for platforms which allow Select2 to be integrated more natively and quickly. For many platforms, additional plugins are not required because Select2 acts as a standard <select> box.

Plugins

Themes

Missing an integration? Modify this README and make a pull request back here to Select2 on GitHub.

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 the separate select2/docs repository.

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.