diff options
| author | Johann-S <[email protected]> | 2017-11-07 12:41:06 +0100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2017-11-07 12:41:06 +0100 |
| commit | 79d6b574cc0946889eb2ef23c765bab50c2a6d60 (patch) | |
| tree | f2fb33479a4278f781e3a22b05e32e7277b04546 | |
| parent | 26dc17bcd23fd2f5fd762c5cb73c6a670bd5f897 (diff) | |
| download | bootstrap-79d6b574cc0946889eb2ef23c765bab50c2a6d60.tar.xz bootstrap-79d6b574cc0946889eb2ef23c765bab50c2a6d60.zip | |
Escape ID in Util.getSelectorFromElement (#24700)
| -rw-r--r-- | js/src/util.js | 13 | ||||
| -rw-r--r-- | js/tests/unit/util.js | 15 |
2 files changed, 27 insertions, 1 deletions
diff --git a/js/src/util.js b/js/src/util.js index 71f93a7c5..ef2cc3c57 100644 --- a/js/src/util.js +++ b/js/src/util.js @@ -87,6 +87,14 @@ const Util = (($) => { } } + function escapeId(selector) { + // we escape IDs in case of special selectors (selector = '#myId:something') + // $.escapeSelector does not exist in jQuery < 3 + selector = typeof $.escapeSelector === 'function' ? $.escapeSelector(selector).substr(1) : + selector.replace(/(:|\.|\[|\]|,|=|@)/g, '\\$1') + + return selector + } /** * -------------------------------------------------------------------------- @@ -112,6 +120,11 @@ const Util = (($) => { selector = element.getAttribute('href') || '' } + // if it's an ID + if (selector.charAt(0) === '#') { + selector = escapeId(selector) + } + try { const $selector = $(document).find(selector) return $selector.length > 0 ? selector : null diff --git a/js/tests/unit/util.js b/js/tests/unit/util.js index 372c6e3f7..7f590cc33 100644 --- a/js/tests/unit/util.js +++ b/js/tests/unit/util.js @@ -4,13 +4,26 @@ $(function () { QUnit.module('util') QUnit.test('Util.getSelectorFromElement should return the correct element', function (assert) { - assert.expect(2) + assert.expect(5) + var $el = $('<div data-target="body"></div>').appendTo($('#qunit-fixture')) assert.strictEqual(Util.getSelectorFromElement($el[0]), 'body') // not found element var $el2 = $('<div data-target="#fakeDiv"></div>').appendTo($('#qunit-fixture')) assert.strictEqual(Util.getSelectorFromElement($el2[0]), null) + + // should escape ID and find the correct element + var $el3 = $('<div data-target="#collapse:Example"></div>').appendTo($('#qunit-fixture')) + $('<div id="collapse:Example"></div>').appendTo($('#qunit-fixture')) + assert.strictEqual(Util.getSelectorFromElement($el3[0]), '#collapse\\:Example') + + // if $.escapeSelector doesn't exist in older jQuery versions (< 3) + var tmpEscapeSelector = $.escapeSelector + delete $.escapeSelector + assert.ok(typeof $.escapeSelector === 'undefined', '$.escapeSelector undefined') + assert.strictEqual(Util.getSelectorFromElement($el3[0]), '#collapse\\:Example') + $.escapeSelector = tmpEscapeSelector }) QUnit.test('Util.typeCheckConfig should thrown an error when a bad config is passed', function (assert) { |
