Maison > Article > interface Web > js implémente la prévisualisation et l'impression en ligne du pdf (version complète)
Ce que je veux écrire aujourd'hui, c'est parce qu'il y a trop peu de choses utiles sur Internet, alors je m'en suis rendu compte sans enthousiasme.
1. Faites-nous part de vos besoins : cliquez sur le titre pour accéder à la page PDF prévisualisée, et la fonction de téléchargement est facultative [de préférence].
2. Résultats de la mise en œuvre :
3. Mise en œuvre du code :
Dépend du pdf. js [Besoin de télécharger le contrôle complet]
Télécharger le site officiel : http://mozilla.github.io/pdf.js/
Cliquez sur "Télécharger" pour accéder à la page de téléchargement
cloner ou télécharger git.
Après le téléchargement, le fichier ressemble à ceci :
[L'accent est mis plus tard sur la façon de déployer et d'assembler le projet]
1. Créez un nouveau projet vide et placez le fichier. Placez-le dans le répertoire racine du projet :
Le cercle rouge est téléchargé depuis le site officiel. Modifiez simplement le nom du fichier et faites-le glisser dans le projet sans y toucher du tout. N'oubliez pas les documents si nécessaire.
La couleur verte est écrite par moi [dowwn.html est un fichier test ; statique est un fichier pdf] Collez le code ci-dessous :
list.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0"> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-touch-fullscreen" content="yes"> <meta name="full-screen" content="yes"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <meta name="format-detection" content="telephone=no"> <meta name="format-detection" content="address=no"> <title>list</title> <style> *{ margin: 0; padding: 0; } .title{ background: #e50041; color: #ffffff; font-size: 16px; } .title{ padding:10px 10px ; } ul{ padding:0px 10px 10px 10px ; } li{ list-style: none; border-bottom: 1px solid #eeeeee; height: 50px; line-height:50px; } a{ text-decoration: none; color: #000; } .leftImg{ width: 30px; vertical-align: middle; } .next{ float: right; /*vertical-align: middle;*/ margin-top: 4.5%; } </style> </head> <body> <p class="title">产品说明书</p> <ul> <li dataSrc = 'KD-122LA火灾探测报警器说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-122LA火灾探测报警器说明书ccc</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-212LA可燃气体探测器说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-212LA 可燃气体探测器说明书</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-216LA可燃气体探测器说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-216LA可燃气体探测器说明书</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'Kd-122LA_KD-601系统遥控器使用说明.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">Kd-122LA KD-601系统遥控器使用说明</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-602LA_SOS一键救助使用说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-602LA SOS一键救助使用说明书</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-701LA_溢水探测器使用说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-701LA 溢水探测器使用说明书</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-702LA红外人体移动探测器说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-702LA红外人体移动探测器说明书</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-703LA_门窗探测器使用说明书.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-703LA 门窗探测器使用说明书</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'KD-805A_WiFi系统主机使用说明书_V1.00.pdf' onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">KD-805A WiFi系统主机使用说明书_V1.00</span> <img class="next" src="img/next.png" alt=""> </li> <li dataSrc = 'WIFI智慧家庭安防系统操作说明书_v0.01.pdf'onclick="fun(this)"> <img class="leftImg" src="img/js implémente la prévisualisation et limpression en ligne du pdf (version complète)" alt=""> <span href="">WIFI智慧家庭安防系统操作说明书_v0.01</span> <img class="next" src="img/next.png" alt=""> </li> </ul> <script src="js/jquery.min.js"></script> <script> function fun(e){ // console.log(e); var dataSrc = $(e).attr('dataSrc'); // console.log(dataSrc); // sessionStorage.setItem('dataSrc',dataSrc); // window.location.href='index.html' var urlSrc = 'http://testweixin.kingdun.net.cn/pdf/static/'+dataSrc; $.ajax({ url: urlSrc, type: "get", success: function(xhr, data){ if (navigator.userAgent.indexOf('Android') > -1) { //判断移动端是android 还是ios ,若是android 则要借助pdf插件 window.location.href = "http://testweixin.kingdun.net.cn/pdf/pdfjs/web/viewer.html?file="+urlSrc; } else { //ios直接打开pdf //window.location.href = url; window.location.href = "http://testweixin.kingdun.net.cn/pdf/pdfjs/web/viewer.html?file="+urlSrc; } }, error: function(){ //window.location.href = '${ctx}/core/user.androidPdf.do?mid='+mid+"&name="+storagename+"&realname="+realname; window.location.href = "http://testweixin.kingdun.net.cn/pdf/js/web/viewer.html?file="+urlSrc; } }); } </script> </body> </html>
【Compatibilité】 : Téléphone mobile Apple : Aperçu directement, il est livré avec le système de téléphonie mobile, mais il ne peut pas être téléchargé (il y a des gains et des pertes), il peut être ouvert dans d'autres applications comme wps.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0"> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-touch-fullscreen" content="yes"> <meta name="full-screen" content="yes"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <meta name="format-detection" content="telephone=no"> <meta name="format-detection" content="address=no"> <title>list</title> <style> *{ margin: 0; padding: 0; } .title{ background: #e50041; color: #ffffff; font-size: 16px; } .title{ padding:10px 10px ; } ul{ padding:0px 10px 10px 10px ; } li{ list-style: none; border-bottom: 1px solid #eeeeee; height: 50px; line-height:50px; } a{ text-decoration: none; color: #000; } .leftImg{ width: 30px; vertical-align: middle; } .next{ float: right; /*vertical-align: middle;*/ margin-top: 4.5%; } </style> </head> <body> <p class="title">产品说明书</p> <a href="static/1.pdf">00001</a> </body> </html>
Haha, utilisez simplement la balise a href pour accéder au fichier pdf ; c'est bien aussi ! [iPhone : aperçu direct ; Android : lien de téléchargement]
Recommandations associées :Fonction d'impression JS Le code peut réaliser un aperçu avant impression, des paramètres d'impression, etc.
JavaScript peut réaliser une impression, un aperçu avant impression, des paramètres d'impression
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!