JS实现jQuery的append功能
HTMLElement.prototype.appendHTML = function(html) {let divTemp = document.createElement('div');let nodes = null;let fragment = document.createDocumentFragment();divTemp.innerHTML = html;nodes = divTemp.childNodes;nodes.forEach(item => {fragment.appendChild(item.cloneNode(true));})// 插入到最后 appendthis.appendChild(fragment);// 在最前插入 prepend// this.insertBefore(fragment, this.firstChild);nodes = null;fragment = null;};测试下效果
html
<style>.child { height: 50px; width: 50px; background: #66CCFF; margin-bottom: 1em;}</style><div id='app'> <div class='child'> <div class='child'></div>
js
let app = document.getElementById(’app’);let child = `<div class='child'>down</div>`;app.appendHTML(child);效果

另外, 如果想实现在上方插入的话, 只需要把代码里的this.appendChild(fragment); 改为 this.insertBefore(fragment, this.firstChild);
另一种方法var div2 = document.querySelector('#div2'); div2.insertAdjacentHTML('beforebegin','<p>hello world</p>');//在调用元素外部前面添加一个元素 div2.insertAdjacentHTML('afterbegin','<p>hello world</p>');//在调用元素的内部添加一个子元素并取代了第一个子元素 div2.insertAdjacentHTML('beforeend','<p>hello world</p>');//在调用元素内部后面添加一个子元素 即取代了最后的子元素 div2.insertAdjacentHTML('afterend','<p>hello world</p>');//在调用元素的外部后面添加一个元素
浏览器的渲染的效果:

此方法是ie 的最早的方法所以兼容性特别好
以上就是JS实现jQuery的append功能的详细内容,更多关于JS 实现jQuery append的资料请关注好吧啦网其它相关文章!
相关文章:
1. Spring Framework 1.2.8发布2. HTML5视频播放标签video和音频播放标签audio标签的正确用法3. ASP基础知识Command对象讲解4. ASP.NET Core 7 Razor Pages项目发布到IIS的详细过程5. Jsp中request的3个基础实践6. Ajax 请求队列解决方案并结合elementUi做全局加载状态7. vue-element-admin中node-sass换成dart-sass,安装依赖报code 128多种问题的解决方法8. 详解如何实现phpoffice的excel导入功能解耦9. 详解CSS故障艺术10. 写给小白学习的地理信息的表示法GeoJSON

网公网安备