Evitare pagine bianche in PDF di output quando non c’è niente da stampare con JavaScript via C++
Contents
[
Hide
]
Possibili Scenari di Utilizzo
Quando il file Excel è vuoto e l’utente lo salva in PDF usando Aspose.Cells for JavaScript via C++, viene generata una pagina bianca nel PDF di output. A volte, questo comportamento predefinito non è desiderato. Aspose.Cells fornisce la proprietà PdfSaveOptions.outputBlankPageWhenNothingToPrint per gestire questo problema. Se la imposti su false, si verificherà un’eccezione ogni volta che non ci sarà niente da stampare nel PDF di output.
Evitare Pagina Vuota nel PDF di Output quando non c’è Nulla da Stampare
Il seguente esempio di codice crea un workbook vuoto e lo salva come PDF impostando la proprietà PdfSaveOptions.outputBlankPageWhenNothingToPrint su false. Poiché non c’è nulla da stampare nel PDF di output, si verifica l’eccezione come mostrato di seguito.
Codice di Esempio
<!DOCTYPE html>
<html>
<head>
<title>Aspose.Cells Example</title>
</head>
<body>
<h1>Save Workbook to PDF Example</h1>
<input type="file" id="fileInput" accept=".xls,.xlsx,.csv" />
<button id="runExample">Run Example</button>
<a id="downloadLink" style="display: none;">Download Result</a>
<div id="result"></div>
</body>
<script src="aspose.cells.js.min.js"></script>
<script type="text/javascript">
const { Workbook, SaveFormat, PdfSaveOptions, Utils } = AsposeCells;
AsposeCells.onReady({
license: "/lic/aspose.cells.enc",
fontPath: "/fonts/",
fontList: [
"arial.ttf",
"NotoSansSC-Regular.ttf"
]
}).then(() => {
console.log("Aspose.Cells initialized");
});
document.getElementById('runExample').addEventListener('click', async () => {
const fileInput = document.getElementById('fileInput');
if (!fileInput.files.length) {
// No file selected - will create an empty workbook (to mirror original JavaScript behavior)
document.getElementById('result').innerHTML = '<p>No file selected. Creating an empty workbook and attempting to save to PDF.</p>';
} else {
document.getElementById('result').innerHTML = '<p>Loading selected workbook...</p>';
}
// Instantiate workbook from file if provided, otherwise create an empty workbook
let workbook;
if (fileInput.files.length) {
const file = fileInput.files[0];
const arrayBuffer = await file.arrayBuffer();
workbook = new Workbook(new Uint8Array(arrayBuffer));
} else {
workbook = new Workbook();
}
// Create Pdf save options.
const opts = new PdfSaveOptions();
// Default value of OutputBlankPageWhenNothingToPrint is true.
// Setting false means - Do not output blank page when there is nothing to print.
opts.outputBlankPageWhenNothingToPrint = false;
// Save workbook to Pdf format.
// Note: If workbook has nothing to print and outputBlankPageWhenNothingToPrint is false,
// this operation may throw an exception which will propagate (no try-catch per requirements).
const outputData = workbook.save(SaveFormat.Pdf, opts);
const blob = new Blob([outputData], { type: 'application/pdf' });
const downloadLink = document.getElementById('downloadLink');
downloadLink.href = URL.createObjectURL(blob);
downloadLink.download = 'output.pdf';
downloadLink.style.display = 'block';
downloadLink.textContent = 'Download PDF File';
document.getElementById('result').innerHTML = '<p style="color: green;">PDF generated successfully. Click the download link to get the file.</p>';
});
</script>
</html>
Eccezione
exception was unhandled
HResult=-2146232832
Message=There is nothing to output/print.
Source=Aspose.Cells
StackTrace:
at Aspose.Cells.Workbook.Save(String fileName, SaveOptions saveOptions)