Online PDF to PNG, PDF to JPEG, PDF to WEBP, PDF to TXT - toolfk程序員在線工具網(wǎng)

? ? ? 本文要推薦的[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視頻下載工具箱

本文鏈接:http://www.hihubs.com/article/400

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市虐呻,隨后出現(xiàn)的幾起案子象泵,更是在濱河造成了極大的恐慌,老刑警劉巖斟叼,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件偶惠,死亡現(xiàn)場離奇詭異,居然都是意外死亡朗涩,警方通過查閱死者的電腦和手機(jī)忽孽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谢床,“玉大人兄一,你說我怎么就攤上這事∈锻龋” “怎么了出革?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長渡讼。 經(jīng)常有香客問我骂束,道長,這世上最難降的妖魔是什么成箫? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任展箱,我火速辦了婚禮,結(jié)果婚禮上蹬昌,老公的妹妹穿的比我還像新娘混驰。我一直安慰自己,他們只是感情好皂贩,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布栖榨。 她就那樣靜靜地躺著,像睡著了一般明刷。 火紅的嫁衣襯著肌膚如雪婴栽。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天遮精,我揣著相機(jī)與錄音居夹,去河邊找鬼败潦。 笑死,一個(gè)胖子當(dāng)著我的面吹牛准脂,可吹牛的內(nèi)容都是我干的劫扒。 我是一名探鬼主播,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼狸膏,長吁一口氣:“原來是場噩夢啊……” “哼沟饥!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起湾戳,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤贤旷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后砾脑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體幼驶,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年韧衣,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了盅藻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡畅铭,死狀恐怖氏淑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情硕噩,我是刑警寧澤假残,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站炉擅,受9級特大地震影響辉懒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜坑资,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一耗帕、第九天 我趴在偏房一處隱蔽的房頂上張望穆端。 院中可真熱鬧袱贮,春花似錦、人聲如沸体啰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽荒勇。三九已至柒莉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間沽翔,已是汗流浹背兢孝。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工窿凤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人跨蟹。 一個(gè)月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓雳殊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親窗轩。 傳聞我的和親對象是個(gè)殘疾皇子夯秃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評論 2 355

推薦閱讀更多精彩內(nèi)容