? ? ? 本文要推薦的[ToolFk]是一款程序員經(jīng)常使用的線上免費(fèi)測試工具箱褂痰,ToolFk 特色是專注于程序員日常的開發(fā)工具霉撵,不用安裝任何軟件枕面,只要把內(nèi)容貼上按一個(gè)執(zhí)行按鈕,就能獲取到想要的內(nèi)容結(jié)果稻轨。ToolFk還支持??BarCode條形碼在線生成、?QueryList采集器蜈敢、?PHP代碼在線運(yùn)行辜荠、?PHP混淆、加密抓狭、解密伯病、?Python代碼在線運(yùn)行、JavaScript在線運(yùn)行否过、YAML格式化工具午笛、HTTP模擬查詢工具、HTML在線工具箱苗桂、JavaScript在線工具箱药磺、CSS在線工具箱、JSON在線工具箱煤伟、Unixtime時(shí)間戳轉(zhuǎn)換癌佩、Base64/URL/Native2Ascii轉(zhuǎn)換、CSV轉(zhuǎn)換工具箱便锨、XML在線工具箱围辙、WebSocket在線工具、Markdown 在線工具箱鸿秆、Htaccess2nginx 轉(zhuǎn)換酌畜、進(jìn)制在線轉(zhuǎn)換怎囚、在線加密工具箱卿叽、在線偽原創(chuàng)工具、在線APK反編譯恳守、在線網(wǎng)頁截圖工具考婴、在線隨機(jī)密碼生成、在線生成二維碼Qrcode催烘、在線Crontab表達(dá)式生成沥阱、在線短網(wǎng)址生成、在線計(jì)算器工具伊群、Linux常用命令大全考杉、在線文本比較工具、在線思維導(dǎo)圖工具舰始、在線數(shù)據(jù)庫設(shè)計(jì)工具崇棠、免費(fèi)CDN加速服務(wù)、在線壓力測試工具丸卷、地圖拾取坐標(biāo)工具枕稀、在線SQL轉(zhuǎn)換工具。等20多個(gè)日常程序員開發(fā)工具,算是一個(gè)非常全面的程序員工具箱網(wǎng)站萎坷。
網(wǎng)站名稱:ToolFk
網(wǎng)站鏈結(jié):https://www.toolfk.com/
工具鏈接:https://www.toolfk.com/tool-convert-pdf
代碼教學(xué)
本工具[Online PDF to image tool, support online PDF to PNG, PDF to JPEG, PDF to WEBP, PDF to TXT - toolfk程序員在線工具網(wǎng)]依賴https://xxlllq.github.io/pdf2img/庫
STEP 1
STEP 2
核心代碼如下
<script>
????$("#export").attr("disabled",?"disabled");
????var?pdfFile;
????var?txtArr?=[];
????$('#pdf').change(function()?{
????????var?load_index?=?layer.load();
????????var?pdfFileURL?=?$('#pdf').val();
????????if(pdfFileURL)?{
????????????$("#imgDiv").empty();
????????????var?files?=?$('#pdf').prop('files');
????????????var?fileSize?=?files[0].size;
????????????var?mb;
????????????if(fileSize)?{
????????????????mb?=?fileSize?/?1048576;
????????????}
????????????$("#export").removeAttr("disabled",?"disabled");
????????????$("#pdfName").text(files[0].name).attr("title",files[0].name);
????????????$("#sizeText").text(mb.toFixed(2)?+?"Mb");
????????????/*pdf.js無法直接打開本地文件,所以利用FileReader轉(zhuǎn)換*/
????????????var?reader?=?new?FileReader();
????????????reader.readAsArrayBuffer(files[0]);
????????????var?load_inner?=?layer.load();
????????????reader.onload?=?function(e)?{
????????????????var?typedarray?=?new?Uint8Array(this.result);
????????????????PDFJS.getDocument(typedarray).then(function(pdf)?{
????????????????????$("#imgDiv").css("border",?"0");
????????????????????if(pdf)?{
????????????????????????var?pageNum?=?pdf.numPages;
????????????????????????$("#pagesText").text(pageNum);
????????????????????????for(var?i?=?1;?i?<=?pageNum;?i++)?{
????????????????????????????var?canvas?=?document.createElement('canvas');
????????????????????????????canvas.id?=?"pageNum"?+?i;
????????????????????????????$("#imgDiv").append(canvas);
????????????????????????????var?context?=?canvas.getContext('2d');
????????????????????????????openPage(pdf,?i,?context);
????????????????????????}
????????????????????}
????????????????????layer.close(load_inner);
????????????????});
????????????};
????????}
????????layer.close(load_index);
????});
????function?wt(wmContext,origCanvas){
????????wmContext.save();
????????wmContext.globalAlpha=0.5;
????????wmContext.textBaseline?=?'middle';
????????wmContext.textAlign?=?'center';
????????wmContext.font?=?"18px?Comic?Sans?MS"?;
????????wmContext.fillStyle?=?"red";
????????wmContext.rotate(180*Math.PI/180);
????????wmContext.fillText("WaterMark?Demo",200,60);
????????wmContext.restore();
????}
????function?openPage(pdfFile,?pageNumber,?context)?{
????????var?scale?=?2;
????????pdfFile.getPage(pageNumber).then(function(page)?{
????????????page.getTextContent().then((textContent)?=>?{
????????????????let?pageText?=?[];
????????????????textContent.items.forEach((textItem)?=>?{
????????????????????pageText.push(textItem.str);
????????????????});
????????????????pageText.join('?');
????????????????txtArr[pageNumber]?=?pageText;
????????????});
????????????viewport?=?page.getViewport(scale);
????????????var?canvas?=?context.canvas;
????????????canvas.width?=?viewport.width;
????????????canvas.height?=?viewport.height;
????????????canvas.style.width?=?"96%";
????????????canvas.style.height?=?"100%";
????????????canvas.className?=?'c_class';
????????????var?renderContext?=?{
????????????????canvasContext:?context,
????????????????viewport:?viewport
????????????};
????????????page.render(renderContext);
????????});
????};
????function?exportType(images,ext,url_ext){
????????$("canvas").each(function(index,?ele)?{
????????????var?canvas?=?document.getElementById("pageNum"?+?(index?+?1));
????????????images.file("image-"?+?(index?+?1)?+?ext,?dataURLtoBlob(canvas.toDataURL(url_ext,?1.0)),?{
????????????????base64:?true
????????????});
????????});
????}
????$("#export").click(function()?{
????????var?modules?????=???$("#modules");
????????var?pdfFileURL?=?$('#pdf').val();
????????if(!pdfFileURL){
????????????layer.msg("@lang('toolfk.lang_convert_pdf_upload').");
????????????return?false;
????????}
????????var?module_val??=???modules.val();
????????if(!module_val){
????????????layer.msg("@lang('toolfk.lang_convert_pdf_convert').");
????????????return?false;
????????}
????????var?zip?=?new?JSZip();
????????var?images?=?zip.folder("toolfk-images");
????????if(module_val?==?"png"){
????????????exportType(images,".png","image/png");
????????}else?if(module_val?==?"jpeg"){
????????????exportType(images,".jpeg","image/jpeg");
????????}else?if(module_val?==?"webp"){
????????????exportType(images,".webp","image/webp");
????????}else?if(module_val?==?"txt"){
????????????var?fullTxt?=?"";
????????????$.each(txtArr,function(index,ele){
????????????????if?(typeof(ele)?!=?"undefined"){
????????????????????fullTxt+=ele;
????????????????}
????????????});
????????????images.file($("#pdfName").text()?+?".txt",""+fullTxt);
????????}else{
????????????layer.msg("@lang('toolfk.lang_convert_pdf_convert').");
????????????return?false;
????????}
????????zip.generateAsync({
????????????type:?"blob"
????????}).then(function(content)?{
????????????saveAs(content,?"toolfk_com_pdf_convert.zip");
????????});
????});
????function?dataURLtoBlob(dataurl)?{
????????var?arr?=?dataurl.split(','),
????????????mime?=?arr[0].match(/:(.*?);/)[1],
????????????bstr?=?atob(arr[1]),
????????????n?=?bstr.length,
????????????u8arr?=?new?Uint8Array(n);
????????while(n--)?{
????????????u8arr[n]?=?bstr.charCodeAt(n);
????????}
????????return?new?Blob([u8arr],?{
????????????type:?mime
????????});
????}
</script>
值得一試的三個(gè)理由:
整合各種程序員開發(fā)中經(jīng)常使用的開發(fā)測試工具凹联。
簡潔美觀大氣的網(wǎng)站頁面
支持 在線格式化執(zhí)行代碼、APK在線反編譯哆档、在線高強(qiáng)度密碼生成蔽挠、在線網(wǎng)頁截圖 等二十多種工具服務(wù)
同時(shí)還推薦一下它的姐妹網(wǎng)www.videofk.com視頻下載工具箱