From 9c98e4e86eda857ee063bc48adbc1a11bb5506ee Mon Sep 17 00:00:00 2001 From: Michał Gołębiowski-Owczarek Date: Wed, 10 Jun 2020 16:13:22 +0200 Subject: Manipulation: Avoid concatenating strings in buildFragment Concatenating HTML strings in buildFragment is a possible security risk as it creates an opportunity of escaping the concatenated wrapper. It also makes it impossible to support secure HTML wrappers like [trusted types](https://web.dev/trusted-types/). It's safer to create wrapper elements using `document.createElement` & `appendChild`. The previous way was needed in jQuery <4 because IE <10 doesn't accept table parts set via `innerHTML`, even if the element which contents are set is a proper table element, e.g.: ```js tr.innerHTML = ""; ``` The whole structure needs to be passed in one HTML string. jQuery 4 drops support for IE <11 so this is no longer an issue; in older version we'd have to duplicate the code paths. IE <10 needed to have `