Alternative Methode des Webdrucks Ausgewählt aus dem Blog von wfmazhenhai
Schlüsselwörter Alternative Methode des Webdrucks
Quelle
Ich glaube, dass jeder, der Anwendungen mit der B/S-Methode erstellt hat, auf ein solches Problem stoßen kann, wie man es erleichtert und schön realisiert Berichtsdruck. Wenn Sie zum Drucken das Druckmenü des Browsers verwenden, werden einige nutzlose Dinge auf der Webseite im Bericht gedruckt, z. B. Anwendungsmenüs usw. Denn wenn Sie zum Drucken einer Webseite das Druckmenü auswählen, wird der gesamte Inhalt der Webseite ausgedruckt. Wenn Ihre Anwendung über Frames verfügt, enthält der gedruckte Inhalt den Inhalt jedes Frames, und der tatsächlich gewünschte Inhalt ist nur ein Teil davon. Daher können viele Anwendungen die Druckfunktion nur im Hintergrund ausführen. Was sollen wir in dieser Situation tun? Tatsächlich gibt es viele Möglichkeiten, die Funktion zum Drucken von Webseiten zu implementieren.
Eine Möglichkeit besteht darin, professionelle Drucktools wie Crystal Reports zu verwenden. Freunde, die Visual Studio 5.0 verwendet haben, werden sich bestimmt an dieses Tool erinnern, allerdings gab es damals nur die Version 4.0. Die neueste Version ist jetzt Version 9 und neuere Versionen von Crystal Reports unterstützen das WEB-Drucken. Die einfachste Methode besteht darin, zunächst mit Crystal Reports eine Vorlage zu erstellen und dann mit ASP die vorbereitete Vorlage mit Parametern aufzurufen. Nachdem Crystal Reports einen Bericht auf der Webseite erstellt hat, kann dieser direkt gedruckt oder in andere Dateien übertragen werden, die den Vergleich bestehen, beispielsweise Excel-Dateien. Mit Crystal Reports können Sie sehr schöne Stile erstellen. Der Schlüssel liegt in Ihrer Fähigkeit, Crystal Reports zu entwickeln. Aufgrund des hohen Preises können Sie sich Crystal Reports jedoch nur leisten, wenn das Projekt sehr profitabel ist.
Die zweite Methode besteht darin, eine Online-Drucksteuerung eines Drittanbieters zu erwerben. Die Kosten sind günstiger als bei Crystal Reports, aber die Wirksamkeit und Leistung sind unterschiedlich.
Die dritte Methode besteht darin, Stylesheets und benutzerdefinierte JavaScript-Funktionen zu verwenden. Das Drucken von Webseiten erfolgt über Stylesheets und JavaScript, und der Effekt ist akzeptabel. Hier ist ein Beispiel, das sich jeder ansehen kann. Im Folgenden finden Sie eine detaillierte Erläuterung der Implementierung der Druckfunktion:
<script language="JavaScript" type="text/JavaScript">
<!--
function DP() {
if ( window.print)
{
var Div1 = document.all.Div1.innerHTML
var Div2 = document.all.Div2.innerHTML; ***** *****************************************
// Div1 und Div2 sind Sie Im Druckbereich
// Je nachdem, welchen Inhalt Sie drucken möchten, verwenden Sie
// <div id=Div1>Div1....</div><div id=Div2> from die ursprüngliche Anzeigeseite Div2...</div>
// Warten Sie, bis sie markiert ist, markieren Sie so viele Elemente, wie Sie drucken möchten
// ************ ********* ************************************ var css = '< style type="text/css" media=all>' +
'p { line-height: 120%}' +
'.ftitle { line-height: 120%; Schriftgröße: 18px; : #000000}' +
'td { Schriftgröße: 10px; Farbe: #000000}' +
'</style>' ; ******************** ******************************
// Definieren Sie das CSS für den Druck, insbesondere das Format, das Sie drucken möchten. Es liegt ganz bei Ihnen
//, aber bitte beachten Sie: Wenn etwas mit der Webseite, dem Format und der Schriftart des Ausdrucks nicht übereinstimmt Seite kann
// von der Webseite abweichen
/ /*********************************** ********************** ****
var body ='<table width="640" border="0" cellpacing="0" cellpadding="5">' +
' <tr> ' +
' < td class="fbody"> ' +
' <div align="center" class=ftitle>' + Div1 + '</div>' + Div2 +
' </td>' +
'</tr>' +
'</table>'
//******; ************************** ************************** **
// Setzen Sie hier das Druckformat zurück und ändern Sie die ursprüngliche Anzeige entsprechend Ihren Druckanforderungen.
// Reorganisieren Sie den DIV-Inhalt der Webseite Sie möchten nicht basierend auf Ihrem ursprünglichen Tabelleninhalt drucken. Sie können auch das unten definierte Noprint verwenden, um die Dinge zu ignorieren, die Sie nicht drucken möchten Platz wird ausgedruckt
// leer, was nicht sehr schön ist. Die Breite des Formulars muss mit der Breite des zu druckenden Papiers übereinstimmen.
//********************************************* *** *********
document.body.innerHTML = '<center>' + css + body + '</center>'// *******; *** ********************************************** *
// Heavy Set document.body, das Druckdokument ist bereit
//**************************** ******** ****************
window.print();
window.history.go(0); ****** ********************************************** **
// Rufen Sie den Druckbefehl auf, um den Inhalt des aktuellen Fensters zu drucken. Beim Drucken handelt es sich tatsächlich um eine neue
//-Webseite, aber die Webseitendatei ist immer noch das Original.Appelez ensuite
// window.history.go(0), puis revenez à la page avant l'impression, l'effet est plutôt bon
// **************** *** *****************************************
}
}
- ->
</script>
<style>
@media print {
.noprint {display:none}
}
</style>
<!-- //.noprint définit noprint. Après avoir ajouté class="noprint" aux endroits suivants qui n'ont pas besoin d'être imprimés, l'impression avec window.print() sera ignorée -->
OK , tout est prêt, que faire maintenant Il s'agit d'appeler la fonction DP Si vous concevez le bouton à appeler sur la même page Web, vous pouvez l'appeler directement si vous utilisez la méthode frame et que le bouton à appeler est ; sur une autre page web, puis dans la fonction DP Ajoutez la commande window.focus() en première ligne, sinon seule la page web avec les boutons sera imprimée.
La quatrième méthode, la mise en œuvre est une méthode délicate. La même chose est obtenue en appelant window.print(), mais le contenu que vous souhaitez imprimer est spécialement généré sous forme de page Web et le bouton d'impression se trouve sur un autre cadre. Supposons que la page Web du rapport se trouve sur le mainFrame et que le bouton se trouve sur le topFrame. Le bouton appelle la fonction PrintReports(). La fonction PrintReports() est la suivante pour réaliser l'impression.
function PrintReports() //Fonction dans la page Web topFrame
{
essayez
//*********************** ******* ***********************************
// Gestion des erreurs , si la page Web dans mainFrame n'a pas de fonction DP Ne pas imprimer
//****************************** ***************** *************
{
window.parent.frames("mainFrame").DP() ;
}
catch(e)
{
alert("aucun objet à imprimer!"
}
}
function DP() // Page web MainFrame function
{
window.focus();
if (window.print)
{
window.print();
}
}
Je pense personnellement c'est la méthode la plus pratique.
Enfin, si vous supprimez les paramètres "En-tête, Coin de page" dans le "Fichier - Paramètres de page" du navigateur IE, l'effet sera meilleur. (Repost)