Maison > développement back-end > Tutoriel C#.Net > Comment utiliser le contrôle d'impression asp.net

Comment utiliser le contrôle d'impression asp.net

高洛峰
Libérer: 2017-01-11 10:26:15
original
1942 Les gens l'ont consulté

Bien que l'effet d'impression et la contrôlabilité ne soient pas très bons, il peut être utilisé à contrecœur et peut gérer l'impression générale.
Le code est le suivant :
Code

//调用PrintControl.ExecWB(?,?)实现直接打印和打印预览功能。(直接用系统提供的print()方法打印无法隐藏某些区域) 
//preview:是否显示预览。null/false:不显示,true:显示 
function printPage(preview) 
{ 
try 
{ 
var content=window.document.body.innerHTML; 
var oricontent=content; 
while(content.indexOf("{$printhide}")>=0) content=content.replace("{$printhide}","style='display:none'"); 
if(content.indexOf("ID=\"PrintControl\"")<0) content=content+"<OBJECT ID=\"PrintControl\" WIDTH=0 HEIGHT=0 CLASSID=\"CLSID:8856F961-340A-11D0-A96B-00C04FD705A2\"></OBJECT>"; 
window.document.body.innerHTML=content; 
//PrintControl.ExecWB(7,1)打印预览,(1,1)打开,(4,1)另存为,(17,1)全选,(10,1)属性,(6,1)打印,(6,6)直接打印,(8,1)页面设置 
if(preview==null||preview==false) PrintControl.ExecWB(6,1); 
else PrintControl.ExecWB(7,1); //OLECMDID_PRINT=7; OLECMDEXECOPT_DONTPROMPTUSER=6/OLECMDEXECOPT_PROMPTUSER=1 
window.document.body.innerHTML=oricontent; 
} 
catch(ex){ alert("执行Javascript脚本出错。"); } 
} 
function printConten(preview, html) 
{ 
try 
{ 
var content=html; 
var oricontent=window.document.body.innerHTML; 
while(content.indexOf("{$printhide}")>=0) content=content.replace("{$printhide}","style=&#39;display:none&#39;"); 
if(content.indexOf("ID=\"PrintControl\"")<0) content=content+"<OBJECT ID=\"PrintControl\" WIDTH=0 HEIGHT=0 CLASSID=\"CLSID:8856F961-340A-11D0-A96B-00C04FD705A2\"></OBJECT>"; 
window.document.body.innerHTML=content; 
//PrintControl.ExecWB(7,1)打印预览,(1,1)打开,(4,1)另存为,(17,1)全选,(10,1)属性,(6,1)打印,(6,6)直接打印,(8,1)页面设置 
if(preview==null||preview==false) PrintControl.ExecWB(6,1); 
else PrintControl.ExecWB(7,1); //OLECMDID_PRINT=7; OLECMDEXECOPT_DONTPROMPTUSER=6/OLECMDEXECOPT_PROMPTUSER=1 
window.document.body.innerHTML=oricontent; 
} 
catch(ex){ alert("执行Javascript脚本出错。"); } 
}
Copier après la connexion

Les deux fonctions ci-dessus sont placées dans un fichier Js, et peuvent être imprimées dans le contenu de la page en appliquant le fichier script et en appelant l'autre fonction encapsulée Spécifiez le contenu de la partie :

<script language="javascript"> 
function Print(preview) { 
var text = document.getElementById("content").innerHTML; 
printConten(preview, text); 
}
Copier après la connexion

L'effet d'impression est à peu près celui indiqué dans la figure ci-dessous. Si la page imprimée est dans une page encadrée, vous devez sélectionner l'option "Imprimer le cadre sélectionné". seulement".

asp.net 打印控件使用方法

En utilisant cette méthode, il n'est pas nécessaire d'installer de contrôles et elle présente de bons avantages en matière de compatibilité. Cependant, le contenu du rapport semble être plus difficile à contrôler, en particulier pour. Certains L'impression de rapports nécessite la sortie d'un contenu complexe, qui présente également certains inconvénients, mais dans l'ensemble, c'est aussi un meilleur choix.

Plus tard, lorsque j'ai eu besoin de travailler sur l'impression de documents, ce contrôle ne pouvait pas le faire, j'avais donc besoin d'une méthode ou d'un contrôle capable de mieux gérer l'impression.

Par inadvertance, j'ai trouvé un meilleur contrôle d'impression qui prend en charge l'impression dans différents formats. Il dispose également de la fonction d'impression d'identité qui me tient à cœur. Il est puissant et facile à utiliser.

En utilisant ce contrôle, l'effet d'impression des rapports ordinaires est le suivant :

asp.net 打印控件使用方法

L'impression des deux rapports ci-dessus est en fait similaire, les deux font partie de l'impression de contenu HTML, mais ce dernier est plus beau et fournit des paramètres de fonction de rapport très complets.

Le code est à peu près le suivant.
Code

<script language="javascript"> 
function Print(preview) { 
var text = document.getElementById("content").innerHTML; 
printConten(preview, text); 
} 
 
 
  
 
Copier après la connexion

Souvent, le contenu que nous n'avons pas est contrôlé par CSS, donc parfois nous imprimons une partie du HTML Sans ces styles, le format Tableau apparaîtra. les polices peuvent toutes changer et cela n'aura pas l'air bien. Ensuite, vous devez définir le style HTML.

asp.net 打印控件使用方法

Si vous définissez un style pour le contenu imprimé, l'effet d'interface sera bien meilleur.

asp.net 打印控件使用方法

Le code pour définir le style est le suivant.
Code

<script language="javascript" type="text/javascript"> 
function Preview() {//打印预览 
CreateLicenseData(); 
LODOP.SET_SHOW_MODE("PREVIEW_IN_BROWSE", 1); 
LODOP.PREVIEW(); 
}; 
function CreateLicenseData() { 
LODOP.PRINT_INIT("申请处理单"); 
var strBodyStyle = "<link type=&#39;text/css&#39; rel=&#39;stylesheet&#39; href=&#39;http://www.cnblogs.com/Themes/Default/style.css&#39; /><style><!--table { border:1;background-color: #CBCBCC } td {background-color:#FFFFFE;border: 1; } th { background-color:#F1F1F3;padding-left:5px;border:1}--></style>"; 
var strFormHtml = strBodyStyle + "<body>" + document.getElementById("content").innerHTML + "</body>"; 
LODOP.ADD_PRINT_HTM(20, 40, 610, 900, strFormHtml); 
LODOP.PREVIEW(); 
} 
</script>
Copier après la connexion

Pour plus d'articles sur l'utilisation du contrôle d'impression asp.net, veuillez faire attention au site Web PHP chinois !

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal