JavaScript中附件預(yù)覽功能實(shí)現(xiàn)詳解(推薦)
由于公司的EMP影像平臺(tái)比較繁瑣,還需要下載才能夠能夠進(jìn)行圖片的預(yù)覽,于是業(yè)務(wù)人員提出在附件列表頁(yè)面增加預(yù)覽頁(yè)面。今天將完成的過程記錄下來:
一種是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è)面寫活
<SCRIPT> var attach_path= '${param.attach_path}'; var attach_name= decodeURI('${param.attach_name}'); var attachPath= new Array(); attachName=attach_name.split(","); var attachPath1= new Array(); attachPath1=attach_path.split(","); for (var i=0;i<attachPath1.length;i++) { attachPath2='102storage'+attachPath1[i]; $("#jq22").append("<li><img alt='"+attachName[i]+"' src='"+attachPath2+"'></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í)間足夠,不過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è)面是訪問不了工程以為的圖片路徑,所以需要執(zhí)行掛載命令將共享磁盤的路徑掛載在工程下的某個(gè)路徑
mount --bind /testshare01 /app/cmis/project/cmis.war/ff/testshare01
這樣就可以正常展示了
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助~如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持!
- JavaScript中附件預(yù)覽功能實(shí)現(xiàn)詳解(推薦)
- java實(shí)現(xiàn)附件預(yù)覽(openoffice+swftools+flexpaper)實(shí)例
- 上傳圖片預(yù)覽JS腳本 Input file圖片預(yù)覽的實(shí)現(xiàn)示例
- js實(shí)現(xiàn)上傳圖片預(yù)覽的方法
- 基于jquery實(shí)現(xiàn)的上傳圖片及圖片大小驗(yàn)證、圖片預(yù)覽效果代碼
- JS預(yù)覽圖像將本地圖片顯示到瀏覽器上
- JS 打印功能代碼可實(shí)現(xiàn)打印預(yù)覽、打印設(shè)置等
- javascript打印大全(打印頁(yè)面設(shè)置/打印預(yù)覽代碼)
- js實(shí)現(xiàn)上傳圖片之上傳前預(yù)覽圖片
相關(guān)文章
javascript 封裝的一個(gè)實(shí)用的焦點(diǎn)圖切換效果
之前有一篇博客,實(shí)用的焦點(diǎn)圖切換效果,結(jié)構(gòu)行為相分離 解釋的比較詳細(xì),腳本是分離式的,但在易用性和重用性方面并不理想,這里原作者進(jìn)行了,優(yōu)化。2010-07-07javascript間隔刷新的簡(jiǎn)單實(shí)例
這篇文章介紹了javascript間隔刷新的簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下2013-11-11webpack組織模塊打包Library的原理及實(shí)現(xiàn)
這篇文章主要介紹了webpack組織模塊打包Library的原理及實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03js 鍵盤記錄實(shí)現(xiàn)(兼容FireFox和IE)
用js實(shí)現(xiàn)鍵盤記錄,要關(guān)注瀏覽器的三種按鍵事件類型,即keydown,keypress和keyup,它們分別對(duì)應(yīng)onkeydown、onkeypress和onkeyup這三個(gè)事件句柄。一個(gè)典型的按鍵會(huì)產(chǎn)生所有這三種事件,依次是keydown,keypress,然后是按鍵釋放時(shí)候的keyup。2010-02-02JavaScript 對(duì)象合并的幾種方法小結(jié)
本文主要介紹了JavaScript 對(duì)象合并的幾種方法小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02