在CKEditor 5经典版中,使用url图像插入对话框而不是上传的方法如下:
<div id="editor"></div>
@ckeditor/ckeditor5-build-classic
和@ckeditor/ckeditor5-image
这两个包。import ClassicEditor from '@ckeditor/ckeditor5-build-classic';
import Image from '@ckeditor/ckeditor5-image/src/image';
ClassicEditor.create( document.querySelector( '#editor' ), {
plugins: [ Image ],
toolbar: [ 'imageTextAlternative', '|', 'imageStyle:full', 'imageStyle:side' ],
image: {
toolbar: [ 'imageTextAlternative', '|', 'imageStyle:full', 'imageStyle:side' ],
styles: [
'full',
'side'
]
}
} )
.then( editor => {
console.log( 'Editor was initialized', editor );
} )
.catch( error => {
console.error( error.stack );
} );
@ckeditor/ckeditor5-image
插件来处理图像操作。这个插件提供了一个默认的上传图像对话框,但我们希望使用url图像插入对话框。为了实现这一点,我们需要在配置中定义自定义对话框。ClassicEditor.create( document.querySelector( '#editor' ), {
// ...
image: {
toolbar: [ 'imageTextAlternative', '|', 'imageStyle:full', 'imageStyle:side', '|', 'imageInsert', 'imageRemove' ],
styles: [ 'full', 'side' ],
customConfig: '',
}
} )
.then( editor => {
editor.plugins.get( 'FileRepository' ).createUploadAdapter = function( loader ) {
return new MyUploadAdapter( loader );
};
console.log( 'Editor was initialized', editor );
} )
.catch( error => {
console.error( error.stack );
} );
MyUploadAdapter
类来替代默认的上传适配器。这个类将处理从url插入图像。class MyUploadAdapter {
constructor( loader ) {
this.loader = loader;
}
upload() {
// 不执行任何上传操作,直接返回一个包含url的Promise对象
return this.loader.file.then( file => {
return new Promise( ( resolve, reject ) => {
const reader = new FileReader();
reader.onload = () => {
resolve( { default: reader.result } );
};
reader.onerror = error => {
reject( error );
};
reader.readAsDataURL( file );
} );
} );
}
abort() {
// 不执行任何操作
}
}
需要注意的是,CKEditor 5经典版不直接提供url图像插入对话框的功能,上述方法是通过自定义上传适配器来实现的。如果你想使用其他定制化的功能,可以根据CKEditor 5的文档进行相应的调整和修改。
以上就是在CKEditor 5经典版中使用url图像插入对话框的方法。关于CKEditor 5的更多信息和其他插件的使用,请参考腾讯云CKEditor产品介绍链接地址:https://cloud.tencent.com/product/ck-editor
领取专属 10元无门槛券
手把手带您无忧上云