Commit d6560bbc authored by Johann-S's avatar Johann-S Committed by XhmikosR
Browse files

better polyfill for closest and matches functions

parent 0b16c8c6
Showing with 39 additions and 15 deletions
+39 -15
...@@ -5,8 +5,45 @@ ...@@ -5,8 +5,45 @@
* -------------------------------------------------------------------------- * --------------------------------------------------------------------------
*/ */
// matches polyfill (see: https://mzl.la/2ikXneG)
let fnMatches = null
if (!Element.prototype.matches) {
fnMatches =
Element.prototype.msMatchesSelector ||
Element.prototype.webkitMatchesSelector
} else {
fnMatches = Element.prototype.matches
}
// closest polyfill (see: https://mzl.la/2vXggaI)
let fnClosest = null
if (!Element.prototype.closest) {
fnClosest = (element, selector) => {
let ancestor = element
if (!document.documentElement.contains(element)) {
return null
}
do {
if (fnMatches.call(ancestor, selector)) {
return ancestor
}
ancestor = ancestor.parentElement
} while (ancestor !== null)
return null
}
} else {
fnClosest = (element, selector) => {
return element.closest(selector)
}
}
const SelectorEngine = { const SelectorEngine = {
matches: Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector, matches(element, selector) {
return fnMatches.call(element, selector)
},
find(selector) { find(selector) {
if (typeof selector !== 'string') { if (typeof selector !== 'string') {
...@@ -22,20 +59,7 @@ const SelectorEngine = { ...@@ -22,20 +59,7 @@ const SelectorEngine = {
}, },
closest(element, selector) { closest(element, selector) {
let ancestor = element return fnClosest(element, selector)
if (!document.documentElement.contains(element)) {
return null
}
do {
if (SelectorEngine.matches.call(ancestor, selector)) {
return ancestor
}
ancestor = ancestor.parentElement
} while (ancestor !== null)
return null
} }
} }
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment