我想在CKEditor中选择一个特定的文本。我使用了以下内容:
var sel = editor.getSelection();
var element = sel.root;
console.log(element);
sel.selectElement(element);
var findString = 'foobar';
var ranges = editor.getSelection().getRanges();
var startIndex = element.getHtml().indexOf(findString);
if (startIndex != -1) {
ranges[0].setStart(element.getFirst(), startIndex);
console.log(element.getFirst() +" - "+ startIndex);
console.log(element.getFirst() +" - "+ startIndex + findString.length);
ranges[0].setEnd(element.getFirst(), startIndex + findString.length);
sel.selectRanges([ranges[0]]);
}
如果它是没有换行符的纯文本,它可以正常工作。 如果我想要选择的文本是在第二行之后或者是格式化的,我会收到以下错误:
未捕获错误:IndexSizeError:DOM异常1
出了什么问题?
答案 0 :(得分:4)
我重新访问了您的代码并“稍微改变了一下”。以下代码将在编辑器内容中选择“the”一词的所有出现次数:
// Note: your instance name may differ.
var editor = CKEDITOR.instances.editor1,
selection = editor.getSelection(),
root = selection.root,
textNodes = [],
ranges = [],
range, text, index;
function getTextNodes( element ) {
var children = element.getChildren(),
child;
for ( var i = children.count(); i--; ) {
child = children.getItem( i );
if ( child.type == CKEDITOR.NODE_ELEMENT )
getTextNodes( child );
else if ( child.type == CKEDITOR.NODE_TEXT )
textNodes.push( child );
}
}
// Recursively search for text nodes starting from root.
// You may want to search a specific branch starting from other element.
getTextNodes( root );
// Iterate over found text nodes. If some contains
// phrase "the", create a range that selects this word.
for ( i = textNodes.length; i--; ) {
text = textNodes[ i ];
index = text.getText().indexOf( 'the' );
if ( index > -1 ) {
range = editor.createRange();
range.setStart( text, index );
// Note: 3 is fixed length of "the". You may want to change it.
range.setEnd( text, index + 3 );
ranges.push( range );
}
}
// Select all ranges "containing" phrase "the".
selection.selectRanges( ranges );
请注意,如果您在Chrome或IE中运行此代码,则只会选择第一次出现。 只有Firefox支持多项选择,结果应如下所示:
我希望这个例子可以帮助你解决问题。