我可以让我的自定义 WYSIWYG 编辑器将样式应用于选定的文本没问题:
pnlDocumentEditor_IFrame.document.execCommand(cmd, ui, opt)
..但我需要做的是允许用户设置字体、字体大小或粗体等,以便在发出此命令后键入的文本将应用该样式。
这可能吗?我尝试过的所有 execCommands 似乎只适用于选定的文本。
我可以让我的自定义 WYSIWYG 编辑器将样式应用于选定的文本没问题:
pnlDocumentEditor_IFrame.document.execCommand(cmd, ui, opt)
..但我需要做的是允许用户设置字体、字体大小或粗体等,以便在发出此命令后键入的文本将应用该样式。
这可能吗?我尝试过的所有 execCommands 似乎只适用于选定的文本。
在某些元素上应用 execCommand,无需用鼠标选择它,可以使用此功能完成:
function execCommandOnElement(el, commandName, value) {
if (typeof value == "undefined") {
value = null;
}
if (typeof window.getSelection != "undefined") {
// Non-IE case
var sel = window.getSelection();
// Save the current selection
var savedRanges = [];
for (var i = 0, len = sel.rangeCount; i < len; ++i) {
savedRanges[i] = sel.getRangeAt(i).cloneRange();
}
// Temporarily enable designMode so that
// document.execCommand() will work
document.designMode = "on";
// Select the element's content
sel = window.getSelection();
var range = document.createRange();
range.selectNodeContents(el);
sel.removeAllRanges();
sel.addRange(range);
// Execute the command
document.execCommand(commandName, false, value);
// Disable designMode
document.designMode = "off";
// Restore the previous selection
sel = window.getSelection();
sel.removeAllRanges();
for (var i = 0, len = savedRanges.length; i < len; ++i) {
sel.addRange(savedRanges[i]);
}
} else if (typeof document.body.createTextRange != "undefined") {
// IE case
var textRange = document.body.createTextRange();
textRange.moveToElementText(el);
textRange.execCommand(commandName, false, value);
}
}
以及示例用法:
var testDiv = document.getElementById("test");
execCommandOnElement(testDiv, "Bold");
execCommandOnElement(testDiv, "ForeColor", "red");