1
0
mirror of synced 2024-11-25 06:16: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 bd7ac9df03
Results respect disabled state of <option> (#5560)
This check is in place in most other places, mostly because we have
run into widespread issues under similar circumstances and we like to
avoid those, but it was forgotten here. There also were no tests
covering this, so it was never caught.

This adds tests that ensure that the option in the results list will
be generated with the correct "disabled" state based on whether or
not it, or a parent element, is marked as disabled.

This should have been easy: just check `element.disabled`

Unfortunately the `disabled` property is not inherited within the
option chain, so if an `<optgroup>` is disabled, the `<option>`
elements or other `<optgroup>` elements held within it do not have
their `disabled` property set to `true`. As a result, we needed to
use the `matches` method to check if the `:disabled` state is
present for the element. The `matches` method is part of the official
standard, but it was not implemented under that name for a while and
as a result Internet Explorer only supports it under the prefixed
`msMatchesSelector` method and older versions of Webkit have it
implemented as `webkitMatchesSelector`. But once we use this method,
it appears to consistently return the expected results.

This `matches` method and prefixed predecessors are not supported in
IE 8, but they are supported in IE 9 and any browsers newer than
that. Instead of buulding a very hacky solution using
`querySelectorAll` that was brittle, I have chosen to act like
everyone else and pretend IE 8 no longer exists.

Fixes #3347
Closes #4818
2019-07-09 20:58:13 -04:00
.github Enable the Stale integration 2019-03-12 22:07:42 -04:00
dist Update dev dependencies (#5529) 2019-06-04 21:18:37 -04:00
docs update README for /docs 2017-09-10 17:57:07 -04:00
src Results respect disabled state of <option> (#5560) 2019-07-09 20:58:13 -04:00
tests Results respect disabled state of <option> (#5560) 2019-07-09 20:58:13 -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.7-rc.0 release 2019-04-30 23:37:24 -04:00
component.json Bump versions for 4.0.7 release 2019-05-07 16:02:59 -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 Update grunt-contrib-qunit to latest version (#5530) 2019-06-04 22:43:52 -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.