mirror of
https://github.com/siyuan-note/siyuan.git
synced 2025-12-20 08:30:12 +01:00
✨ https://github.com/siyuan-note/siyuan/issues/2911 粘贴带样式的行内元素到另一个行内元素中需进行切割
This commit is contained in:
parent
6b82e98eb0
commit
b5e4ccf8c5
2 changed files with 14 additions and 15 deletions
|
|
@ -87,6 +87,20 @@ export const insertHTML = (html: string, protyle: IProtyle, isBlock = false) =>
|
|||
if (tempElement.content.firstChild.nodeType !== 3 && tempElement.content.firstElementChild.classList.contains("p")) {
|
||||
tempElement.innerHTML = tempElement.content.firstElementChild.firstElementChild.innerHTML.trim();
|
||||
}
|
||||
// 粘贴带样式的行内元素到另一个行内元素中需进行切割
|
||||
const spanElement = range.startContainer.nodeType === 3 ? range.startContainer.parentElement: range.startContainer as HTMLElement;
|
||||
if (spanElement.tagName === "SPAN" && spanElement.isSameNode( range.endContainer.nodeType === 3 ? range.endContainer.parentElement: range.endContainer)) {
|
||||
const afterElement = document.createElement("span");
|
||||
const attributes = spanElement.attributes;
|
||||
for (let i = 0; i < attributes.length; i++) {
|
||||
afterElement.setAttribute(attributes[i].name, attributes[i].value);
|
||||
}
|
||||
range.setEnd(spanElement.lastChild, spanElement.lastChild.textContent.length);
|
||||
afterElement.append(range.extractContents());
|
||||
spanElement.after(afterElement);
|
||||
range.setStartBefore(afterElement);
|
||||
range.collapse(true);
|
||||
}
|
||||
range.insertNode(tempElement.content.cloneNode(true));
|
||||
range.collapse(false);
|
||||
blockElement.setAttribute("updated", dayjs().format("YYYYMMDDHHmmss"));
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue