当前位置: 代码迷 >> 综合 >> 用 JS 原生方法实现 jQuery 的 append, prepend, before, after
  详细解决方案

用 JS 原生方法实现 jQuery 的 append, prepend, before, after

热度:71   发布时间:2024-01-11 20:23:44.0

相当于 $(el).before('html' | element)

el.insertAdjacentHTML('beforeBegin', 'html');
el.insertAdjacentElement('beforebegin', element)

相当于 $(el).prepend('html' | element)

el.insertAdjacentHTML('afterBegin', 'html');
el.insertBefore(element, el.firstChild)

相当于 $(el).append('html' | element)

el.insertAdjacentHTML('beforeEnd', 'html');
el.appendChild(element)

相当于 $(el).after('html' | element)

el.insertAdjacentHTML('afterEnd', 'html');
el.insertAdjacentElement('afterend', element)

相当于 $(el).addClass(className)

el.classList.add(className)

相当于 $(el).removeClass(className)

el.classList.remove(className)

相当于 $(el).toggleClass(className)

el.classList.toggle(className)

相当于 $(el).offset()

var rect = el.getBoundingClientRect();{top: rect.top + document.body.scrollTop,left: rect.left + document.body.scrollLeft
}

相当于 $(el).remove()

el.parentNode.removeChild(el)

相当于 $(el).on(eventName, eventHandler)

el.addEventListener(eventName, eventHandler)

相当于 $(el).off(eventName, eventHandler)

el.removeEventListener(eventName, eventHandler)

相当于 $(document).on(eventName, elementSelector, handler)

document.addEventListener(eventName, function(e) {const handler = function(e) {console.log(this)console.log(e)}for (var target = e.target; target && target != this; target = target.parentNode) {if (target.matches(elementSelector)) {handler.call(target, e);break;}}
}, false);
  相关解决方案