swup
Version:
Versatile and extensible page transition library for server-rendered websites
33 lines (27 loc) • 742 B
text/typescript
import { query } from '../utils.js';
/**
* Find the anchor element for a given hash.
*
* @param hash Hash with or without leading '#'
* @returns The element, if found, or null.
*
* @see https://html.spec.whatwg.org/#find-a-potential-indicated-element
*/
export const getAnchorElement = (hash?: string): Element | null => {
if (hash && hash.charAt(0) === '#') {
hash = hash.substring(1);
}
if (!hash) {
return null;
}
const decoded = decodeURIComponent(hash);
let element =
document.getElementById(hash) ||
document.getElementById(decoded) ||
query(`a[name='${CSS.escape(hash)}']`) ||
query(`a[name='${CSS.escape(decoded)}']`);
if (!element && hash === 'top') {
element = document.body;
}
return element;
};