在 CkEditor 中获取选定的文件并添加自定义上传按钮
get selected file in CkEditor & add custom upload button
- 我正在使用 ngx-ckeditor: angular 中的“0.4.0” 5.
- 我要上传图片并添加自定义上传按钮
下面是我的html.
<ck-editor
#ckeditor
name="html_template"
[(ngModel)]="mailModel.html_template"
[config]="ckEditorConfig">
</ck-editor>
这是我的组件代码。
this.ckEditorConfig = {
filebrowserBrowseUrl : '/application/crm/distribution-list/create-mail',
filebrowserUploadUrl : 'http://192.168.0.107:8000/api/crm/v1.0/crm-distribution-library-files',
fileTools_requestHeaders :{
'X-Requested-With': 'XMLHttpRequest',
Authorization: 'Bearer ' + localStorage.getItem('access_token')
},
filebrowserUploadMethod : 'xhr',
removeButtons: 'Forms,Iframe,Blocks,Subscript,Superscript,Maximize,Undo',
};
使用此代码我无法获取图像并且无法通过我的自定义 header。
i want to get selected image & add custom 'Upload Image' button.
下面是在CkEditor中添加自定义按钮的代码
@ViewChild('ckeditor') ckeditor: CKEditorComponent;
ngAfterViewInit(): void {
this._addImageUploadBtn();
}
_addImageUploadBtn() {
const editor = this.ckeditor && this.ckeditor.instance;
if (!editor) {
return;
}
var that = this;
editor.ui.addButton('uploadImage', {
icon: 'https://img.icons8.com/ios/50/000000/image.png',
label: 'Upload Image',
command: 'uploadImage',
toolbar: 'insert'
});
editor.addCommand('uploadImage', {
exec: function(editor: any) {
// Remove img input.
[].slice.apply(document.querySelectorAll('.ck-editor-upload-img')).forEach((img: any) => {
img.remove();
});
const input = document.createElement('input');
input.setAttribute('type', 'file');
input.setAttribute('class', 'ck-editor-upload-img');
input.style.display = 'none';
input.addEventListener('change', e => {
const file = (e.target as HTMLInputElement).files[0];
if (file) {
console.log(file);
// Do Stuff
}
},
false
);
document.body.appendChild(input);
input.click();
}
});
}
here you get the selected image file, and also get custom button click.
- 我正在使用 ngx-ckeditor: angular 中的“0.4.0” 5.
- 我要上传图片并添加自定义上传按钮
下面是我的html.
<ck-editor #ckeditor name="html_template" [(ngModel)]="mailModel.html_template" [config]="ckEditorConfig"> </ck-editor>
这是我的组件代码。
this.ckEditorConfig = { filebrowserBrowseUrl : '/application/crm/distribution-list/create-mail', filebrowserUploadUrl : 'http://192.168.0.107:8000/api/crm/v1.0/crm-distribution-library-files', fileTools_requestHeaders :{ 'X-Requested-With': 'XMLHttpRequest', Authorization: 'Bearer ' + localStorage.getItem('access_token') }, filebrowserUploadMethod : 'xhr', removeButtons: 'Forms,Iframe,Blocks,Subscript,Superscript,Maximize,Undo', };
使用此代码我无法获取图像并且无法通过我的自定义 header。
i want to get selected image & add custom 'Upload Image' button.
下面是在CkEditor中添加自定义按钮的代码
@ViewChild('ckeditor') ckeditor: CKEditorComponent;
ngAfterViewInit(): void {
this._addImageUploadBtn();
}
_addImageUploadBtn() {
const editor = this.ckeditor && this.ckeditor.instance;
if (!editor) {
return;
}
var that = this;
editor.ui.addButton('uploadImage', {
icon: 'https://img.icons8.com/ios/50/000000/image.png',
label: 'Upload Image',
command: 'uploadImage',
toolbar: 'insert'
});
editor.addCommand('uploadImage', {
exec: function(editor: any) {
// Remove img input.
[].slice.apply(document.querySelectorAll('.ck-editor-upload-img')).forEach((img: any) => {
img.remove();
});
const input = document.createElement('input');
input.setAttribute('type', 'file');
input.setAttribute('class', 'ck-editor-upload-img');
input.style.display = 'none';
input.addEventListener('change', e => {
const file = (e.target as HTMLInputElement).files[0];
if (file) {
console.log(file);
// Do Stuff
}
},
false
);
document.body.appendChild(input);
input.click();
}
});
}
here you get the selected image file, and also get custom button click.