您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關JavaScript中如何實現附件預覽功能的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
由于公司的EMP影像平臺比較繁瑣,還需要下載才能夠能夠進行圖片的預覽,于是業務人員提出在附件列表頁面增加預覽頁面。今天將完成的過程記錄下來:
一種是js版本的,另一種是jquery版本, 在這里使用的是js版本的。jquery版本只是引入方式略有不同。
1.引入插件(已上傳)
<SCRIPT src="styles/ccc/jquery.min.js"></SCRIPT>
<SCRIPT src="styles/ccc/viewer-jquery.min.js"></SCRIPT>
2.將預覽頁面寫活
<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>
將圖片的路徑從之前的列表頁面傳到預覽頁面,進行圖片預覽時既可以多選又可以不選,如果不選則默認展示本列表所有的圖片,勾選的話則展示勾選的之后的圖片,在這里發現APP上傳了許多的圖片的壓縮包,所以在后臺增加了自動解壓的*.zip,*.rar的功能,這部分需要引入第三方jar包,1.6的僅支持*.zip格式的解壓,并且最坑的sun公司默認編碼,如果有中文就會報錯,到jdk1.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.異步刪除解壓文件
考慮到解壓之后的會占用共享磁盤的空間,所以在解壓之后做異步刪除,時間在20s之后,時間足夠,不過20s之后如果點擊重新加載頁面的話會圖片加載失敗,因為圖片的路徑已經失效了。
//異步刪除文件(節省空間) 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.磁盤掛載
在顯示圖片的時候,頁面是訪問不了工程以為的圖片路徑,所以需要執行掛載命令將共享磁盤的路徑掛載在工程下的某個路徑
mount --bind /testshare01 /app/cmis/project/cmis.war/ff/testshare01
這樣就可以正常展示了
感謝各位的閱讀!關于“JavaScript中如何實現附件預覽功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。