JS implements jQuery's append function

JS implements jQuery's append function

Show Me The Code

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));
	})
	// Insert to the end append
	this.appendChild(fragment);
	// Insert prepend at the front
	// this.insertBefore(fragment, this.firstChild);
	nodes = null;
	fragment = null;
};

Test the effect

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);

Effect

PS

In addition, if you want to insert above, just change this.appendChild(fragment); in the code to this.insertBefore(fragment, this.firstChild);

Another approach

var div2 = document.querySelector("#div2");
  div2.insertAdjacentHTML("beforebegin","<p>hello world</p>");//Add an element before the calling elementdiv2.insertAdjacentHTML("afterbegin","<p>hello world</p>");//Add a child element inside the calling element and replace the first child elementdiv2.insertAdjacentHTML("beforeend","<p>hello world</p>");//Add a child element after the calling element and replace the last child elementdiv2.insertAdjacentHTML("afterend","<p>hello world</p>");//Add an element after the calling element

The effect of browser rendering:

This method is the earliest method of IE, so the compatibility is particularly good

The above is the details of JS implementing jQuery's append function. For more information about JS implementing jQuery append, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Analysis of four common methods of adding new content to jQuery [append, prepend, after, before]
  • Solve the problem that the element event added by jQuery using append is invalid
  • Comparison of jQuery append and appendTo methods
  • jQuery append elements append, prepend, before, after usage and difference analysis
  • Solution to the problem of jQuery selector causing append failure in IE7
  • jquery append dynamically added element event on does not work solution
  • jQuery uses append to add multiple contents at the same time after the html element
  • Solve the problem of binding events after Jquery appends new elements to the page
  • jQuery appendTo() method usage example
  • jQuery append() method usage examples

<<:  How to set up the terminal to run applications after Ubuntu starts

>>:  How InnoDB cleverly implements transaction isolation levels

Recommend

Tutorial on how to modify element.style inline styles

Preface When we were writing the web page style a...

js tag syntax usage details

Table of contents 1. Introduction to label statem...

5 issues you should pay attention to when making a web page

1. Color matching problem <br />A web page s...

MySQL 5.7.31 64-bit free installation version tutorial diagram

1. Download Download address: https://dev.mysql.c...

Detailed explanation of Excel parsing and exporting based on Vue

Table of contents Preface Basic Introduction Code...

Detailed explanation of mixed inheritance in Vue

Table of contents The effect of mixed inheritance...

NodeJs high memory usage troubleshooting actual combat record

Preface This is an investigation caused by the ex...

Using Docker Enterprise Edition to build your own private registry server

Docker is really cool, especially because it'...

Markup Language - List

Standardized design solutions - markup languages ...

Solve the problem of case sensitivity of Linux+Apache server URL

I encountered a problem today. When entering the ...

Will the index be used in the MySQL query condition?

When an employer asks you whether an index will b...

Solution to Vue3.0 error Cannot find module'worker_threads'

I'll record my first attempt at vue3.0. When ...

How to deploy Confluence and jira-software in Docker

version: centos==7.2 jdk==1.8 confluence==6.15.4 ...