溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JavaScript中如何實(shí)現(xiàn)附件預(yù)覽功能

發(fā)布時(shí)間:2021-07-09 16:18:57 來(lái)源:億速云 閱讀:231 作者:小新 欄目:web開(kāi)發(fā)

這篇文章給大家分享的是有關(guān)JavaScript中如何實(shí)現(xiàn)附件預(yù)覽功能的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

由于公司的EMP影像平臺(tái)比較繁瑣,還需要下載才能夠能夠進(jìn)行圖片的預(yù)覽,于是業(yè)務(wù)人員提出在附件列表頁(yè)面增加預(yù)覽頁(yè)面。今天將完成的過(guò)程記錄下來(lái):

一種是js版本的,另一種是jquery版本, 在這里使用的是js版本的。jquery版本只是引入方式略有不同。

1.引入插件(已上傳)

<SCRIPT src="styles/ccc/jquery.min.js"></SCRIPT>
 
<SCRIPT src="styles/ccc/viewer-jquery.min.js"></SCRIPT>

2.將預(yù)覽頁(yè)面寫(xiě)活

<SCRIPT>
var attach_path= '${param.attach_path}';
var attach_name= decodeURI('${param.attach_name}');
var attachPath= new Array();
attachName=attach_name.split(",");
var attachPath2= new Array();
attachPath2=attach_path.split(",");
for (var i=0;i<attachPath2.length;i++)
{ 
 attachPath3='102storage'+attachPath2[i];
 $("#jq22").append("<li><img alt='"+attachName[i]+"' src='"+attachPath3+"'></li>"); 
}
$(function() {
 $('#jq22').viewer({
  url: 'data-original',
 });
});
</SCRIPT>

將圖片的路徑從之前的列表頁(yè)面?zhèn)鞯筋A(yù)覽頁(yè)面,進(jìn)行圖片預(yù)覽時(shí)既可以多選又可以不選,如果不選則默認(rèn)展示本列表所有的圖片,勾選的話則展示勾選的之后的圖片,在這里發(fā)現(xiàn)APP上傳了許多的圖片的壓縮包,所以在后臺(tái)增加了自動(dòng)解壓的*.zip,*.rar的功能,這部分需要引入第三方j(luò)ar包,1.6的僅支持*.zip格式的解壓,并且最坑的sun公司默認(rèn)編碼,如果有中文就會(huì)報(bào)錯(cuò),到j(luò)dk1.7才支持中文

import java.io.*; 
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.List;
import org.apache.tools.zip.ZipEntry;
import org.apache.tools.zip.ZipFile;
import com.yucheng.cmis.operation.CMISOperation;
import com.github.junrar.Archive;
import com.github.junrar.rarfile.FileHeader;

3.異步刪除解壓文件

考慮到解壓之后的會(huì)占用共享磁盤的空間,所以在解壓之后做異步刪除,時(shí)間在20s之后,時(shí)間足夠,不過(guò)20s之后如果點(diǎn)擊重新加載頁(yè)面的話會(huì)圖片加載失敗,因?yàn)閳D片的路徑已經(jīng)失效了。

   //異步刪除文件(節(jié)省空間)
   List<Thread> threadList = new ArrayList<Thread>();
   Thread thread = new Thread(new DeleteTemporaryFolder(dstDirectoryPath));
   thread.start();
   for(Thread t : threadList){
    try {
     t.join();
    } catch (InterruptedException e) {
     e.printStackTrace();
    }
   }

4.磁盤掛載

在顯示圖片的時(shí)候,頁(yè)面是訪問(wèn)不了工程以為的圖片路徑,所以需要執(zhí)行掛載命令將共享磁盤的路徑掛載在工程下的某個(gè)路徑

mount --bind /testshare01 /app/cmis/project/cmis.war/ff/testshare01

這樣就可以正常展示了

感謝各位的閱讀!關(guān)于“JavaScript中如何實(shí)現(xiàn)附件預(yù)覽功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI