CKFinder Ajax 文件預(yù)覽功能允許用戶(hù)在不離開(kāi)當(dāng)前頁(yè)面的情況下查看和打開(kāi)文件。要實(shí)現(xiàn)這一功能,您需要遵循以下步驟:
<head>
部分添加以下代碼來(lái)實(shí)現(xiàn)這一點(diǎn):<script src="//ckeditor.cdn.telerik.com/2021.2.616/ckfinder/ckfinder.js"></script>
CKFinder.replace()
方法初始化 CKFinder。這將替換當(dāng)前頁(yè)面上的 <input type="file">
元素,并允許用戶(hù)選擇文件。CKFinder.replace('input[type="file"]');
請(qǐng)確保將 'input[type="file"]'
替換為您的 HTML 文件中用于選擇文件的實(shí)際 <input>
元素的 ID。
fileSelected
事件。當(dāng)用戶(hù)選擇一個(gè)文件時(shí),此事件將被觸發(fā)。您可以在此事件的處理程序中執(zhí)行文件預(yù)覽操作。CKFinder.on('fileSelected', function (evt) {
var file = evt.data.file;
previewFile(file);
});
fileSelected
事件處理程序中,調(diào)用一個(gè)名為 previewFile
的函數(shù),并將所選文件作為參數(shù)傳遞。以下是一個(gè)使用 HTML5 FileReader API 的示例實(shí)現(xiàn):function previewFile(file) {
var reader = new FileReader();
reader.onload = function (e) {
var container = document.getElementById('file-preview');
if (!container) {
container = document.createElement('div');
container.id = 'file-preview';
document.body.appendChild(container);
}
var img = document.createElement('img');
img.src = e.target.result;
container.appendChild(img);
};
reader.readAsDataURL(file);
}
在這個(gè)示例中,我們首先創(chuàng)建一個(gè)名為 file-preview
的 <div>
元素(如果尚不存在),然后使用 FileReader API 讀取所選文件并將其轉(zhuǎn)換為 DataURL。最后,我們將 DataURL 設(shè)置為 <img>
元素的 src
屬性,從而在頁(yè)面上預(yù)覽文件。
現(xiàn)在,當(dāng)用戶(hù)通過(guò) CKFinder 選擇一個(gè)文件時(shí),它將在頁(yè)面上預(yù)覽。請(qǐng)注意,這個(gè)示例僅適用于圖像文件。如果您需要預(yù)覽其他類(lèi)型的文件(如 PDF、文檔等),您可能需要使用其他方法或庫(kù)(如 PDF.js、ViewerJS 等)。