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)

Dies ist der 3. Beitrag in einer kleinen Serie, die wir in Form von Barrierefreiheit gemacht haben. Wenn Sie den zweiten Beitrag verpasst haben, lesen Sie "Verwalten des Benutzerfokus mit: Fokus-Sichtbar". In

Die CSS-Box-Shadow- und Umrisseigenschaften haben Thema gewonnen. JSON-Unterstützung in WordPress 6.1. Sei ein paar Beispiele für die Funktionsweise in realen Themen und welche Optionen wir diese Stile auf WordPress -Blöcke und Elemente anwenden müssen.

Wenn Sie kürzlich mit GraphQL gearbeitet oder seine Vor- und Nachteile überprüft haben, haben Sie zweifellos Dinge wie "GraphQL nicht unterstützen Caching" oder gehört

Die Sufelte Transition -API bietet eine Möglichkeit, Komponenten zu beleben, wenn sie das Dokument eingeben oder verlassen, einschließlich benutzerdefinierter Svelte -Übergänge.

In diesem Artikel werden wir in die Welt der Scrollbars eintauchen. Ich weiß, es klingt nicht zu glamourös, aber vertrau mir, eine gut gestaltete Seite geht Hand in Hand

Wie viel Zeit damit, die Inhaltspräsentation für Ihre Websites zu entwerfen? Wenn Sie einen neuen Blog -Beitrag schreiben oder eine neue Seite erstellen, denken Sie darüber nach

Mit dem jüngsten Aufstieg von Bitcoins Preis über 20.000 USD und kürzlich von 30.000, dachte ich, es lohnt

NPM-Befehle führen verschiedene Aufgaben für Sie aus, entweder als einmalige oder als kontinuierlich ausgeführter Vorgang für Dinge wie das Starten eines Servers oder das Kompilieren von Code.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Dreamweaver Mac
Visuelle Webentwicklungstools