Я использовал этот метод , чтобы скопировать форматированный текст из HTML-элемента.Проблема заключается в том, что если стили не встроены в HTML, а исходят из CSS, этот метод не работает.Существующий код нарушает форматирование и не учитывает стили.Вот код:
HTML
<button onclick="copyToClip(document.getElementById('foo').innerHTML)">
Copy the stuff
</button>
<div id=foo>
You can write some JS to generate this data.
It can contain rich stuff.
<b> test </b> me <i> also </i>
<div class="green">Hello world</div> You can use setData to put TWO COPIES into the same clipboard, one that is plain and one that is rich. That way your users can paste into either a
<ul>
<li>plain text editor</li>
<li>or into a rich text editor</li>
</ul>
</div>
CSS
.green {
display: inline;
color: green;
}
JavaScript
function copyToClip(str) {
function listener(e) {
e.clipboardData.setData("text/html", str);
e.clipboardData.setData("text/plain", str);
e.preventDefault();
}
document.addEventListener("copy", listener);
document.execCommand("copy");
document.removeEventListener("copy", listener);
};
Пример в Codepen .