Blog Post

How to build a Vue.js Excel (XLS and XLSX) viewer

Illustration: How to build a Vue.js Excel (XLS and XLSX) viewer

In this blog post, you’ll learn how to build a Vue.js Excel viewer using the Nutrient Web SDK. You’ll open and view XLS or XLSX files directly in your web browser using client-side processing (no server required).

The image below shows what you’ll be building.

You can check out the demo to see it in action.

Opening and rendering Office documents in the browser

Nutrient Web SDK brings support for Word, Excel, and PowerPoint formats to your application, without you or your users needing any MS Office software, MS Office licenses, or third-party open source software. The technology works by converting an Office document to PDF directly in the browser, which is then rendered in our JavaScript viewer.

Unlocking more capabilities with Office-to-PDF conversion

​​By converting an Office document to PDF using client-side JavaScript, you have the option to support a rich array of additional Office document functionality, such as:

  • Text editing — Edit text directly in the displayed Office document.

  • Page manipulation — Organize documents by adding, removing, or rearranging pages.

  • Annotations — Boost collaboration by adding text highlights, comments, or stamps.

  • Adding signatures — Draw, type, or upload a signature directly to an Office document.

Explore Demo

Requirements to get started

To get started, you’ll need:

  • Git
  • Node.js (this article uses version 16.13.0)
  • A package manager for installing the Vue command-line interface (CLI) and importing packages — you can use npm or Yarn

Installing the Vue CLI

To work with Vue.js, you need to install the Vue CLI, which is standard tooling for Vue.js. It helps you create, build, and run Vue.js applications.

You can install the CLI using npm, which comes with Node.js, or yarn:

npm install -g @vue/cli
yarn global add @vue/cli

You can check the version of Vue by running the following:

vue --version

This blog post uses Vue CLI version 5.0.8.

Creating the project

Now, it’s time to integrate Nutrient into your Vue.js project.

  1. Vue CLI provides an easy way of creating projects using the following command:

vue create pspdfkit-vue-project

Here, you’re using the create option with the name of the project you want to create (pspdfkit-vue-project).

It’ll then ask some configuration questions.

  1. Select Default (Vue 3) ([Vue 3] babel, eslint) from the list.

screen showing the vue.js project creation

  1. Now, change the directory to pspdfkit-vue-project:

cd pspdfkit-vue-project

Adding Nutrient

  1. Install pspdfkit as a dependency with npm or yarn:

npm install pspdfkit
yarn add pspdfkit
  1. Now you can start building your Vue.js project. First, create a js directory under the public directory. Go to your terminal and run the following:

mkdir -p public/js
  1. Copy the Nutrient Web SDK library assets to the public/js directory:

cp -R ./node_modules/pspdfkit/dist/pspdfkit-lib public/js/pspdfkit-lib

This will copy the pspdfkit-lib directory from within node_modules/ into the public/js/ directory to make it available to the SDK at runtime.

Displaying an Excel document

  1. Add an Excel (XLS, XLSX) document you want to display to the public directory. You can use our demo document as an example.

  2. Add a component wrapper for the Nutrient library and save it as src/components/PSPDFKitContainer.vue:

// src/components/PSPDFKitContainer.vue

<template>
	<div class="doc-container"></div>
</template>

<script>
import PSPDFKit from 'pspdfkit';

export default {
	name: 'PSPDFKit',
	/**
	 * The component receives the `pdfFile` prop, which is of type `String` and is required.
	 */
	props: {
		excelFile: {
			type: String,
			required: true,
		},
	},
	/**
	 * We wait until the template has been rendered to load the document into the library.
	 */
	mounted() {
		this.loadPSPDFKit().then((instance) => {
			this.$emit('loaded', instance);
		});
	},
	/**
	 * We watch for `pdfFile` prop changes and trigger unloading and loading when there's a new document to load.
	 */
	watch: {
		excelFile(val) {
			if (val) {
				this.loadPSPDFKit();
			}
		},
	},
	/**
	 * Our component has the `loadPSPDFKit` method. This unloads and cleans up the component and triggers document loading.
	 */
	methods: {
		async loadPSPDFKit() {
			PSPDFKit.unload('.doc-container');
			return PSPDFKit.load({
				// To access the `pdfFile` from props, use `this` keyword.
				document: this.excelFile,
				container: '.doc-container',
			});
		},
	},

	/**
	 * Clean up when the component is unmounted so it's ready to load another document (not needed in this example).
	 */
	beforeUnmount() {
		PSPDFKit.unload('.doc-container');
	},
};
</script>

<style scoped>
.doc-container {
	height: 100vh;
}
</style>

Here’s what’s happening in the component:

  • The template section is rendering a div with the doc-container class. This will help you declaratively bind the rendered DOM to the underlying component instance’s data.

  • The script section is defining a Vue.js instance named PSPDFKit and creating methods for mounting, loading, and unloading PDF files into the doc-container.

  • The style section is defining the height of the container.

  1. Now, replace the contents of src/App.vue with the following:

// src/App.vue

<template>
	<div id="app">
		<label for="file-upload" class="custom-file-upload">
			Open Excel
		</label>
		<input
			id="file-upload"
			type="file"
			@change="openDocument"
			class="btn"
		/>
		<PSPDFKitContainer
			:excelFile="excelFile"
			@loaded="handleLoaded"
		/>
	</div>
</template>

<script>
import PSPDFKitContainer from '@/components/PSPDFKitContainer';

export default {
	data() {
		return {
			excelFile: this.excelFile || '/chart.xlsx',
		};
	},
	/**
	 * Render the `PSPDFKitContainer` component.
	 */
	components: {
		PSPDFKitContainer,
	},
	/**
	 * Our component has two methods — one to check when the document is loaded, and the other to open the document.
	 */
	methods: {
		handleLoaded(instance) {
			console.log('PSPDFKit has loaded: ', instance);
			// Do something.
		},

		openDocument() {
			// To access the Vue instance data properties, use `this` keyword.
			if (this.excelFile) {
				window.URL.revokeObjectURL(this.excelFile);
			}
			this.excelFile = window.URL.createObjectURL(
				event.target.files[0],
			);
		},
	},
};
</script>

<style>
#app {
	text-align: center;
	color: #2c3e50;
}

body {
	margin: 0;
}

input[type='file'] {
	display: none;
}

.custom-file-upload {
	border: 1px solid #ccc;
	border-radius: 4px;
	display: inline-block;
	padding: 6px 12px;
	cursor: pointer;
	background: #4a8fed;
	padding: 10px;
	color: #fff;
	font: inherit;
	font-size: 16px;
	font-weight: bold;
}
</style>
  • In the template section, you have a file upload input and the PSPDFKitContainer component.

Information

Vue.js uses directives to handle some types of functionality. For the input field, you’re using the 'v-on' directive to attach an event listener to the element. In this case, it’s the 'change' event. There’s a shortcut to 'v-on' that removes the keyword and uses an '@' symbol instead.

v-on:change="openDocument"
v-on:loaded="handleLoaded"
// Or
@change="openDocument"
@loaded="handleLoaded"

Similar to the input field, for the PSPDFKitContainer component, you’re using the v-bind directive to bind the excelFile property to the excelFile property of the component and attaching an event listener for the loaded event:

<PSPDFKitContainer :excelFile="excelFile" @loaded="handleLoaded" />
  • In the script section, you can see the implementation of the handleLoaded and openDocument methods. There’s also a data function that returns the excelFile property.

The data keeps track of reactive state within the current component. It’s always a function and returns an object. The object’s top-level properties are exposed via the component instance.

  • In the style section, there are styles for custom file input, and there are some general styles for the app.

  1. Start the app:

npm run serve
yarn serve

You can see the application running on localhost:8080.

If you can’t see your Excel file rendered in the browser, make sure you actually uploaded an XLS or XLSX file inside the public directory.

In the demo application, you can open different Excel files by clicking the Open Excel button. You can add signatures, annotations, stamps, and more.

A note about fonts

In client-side web applications for Microsoft Office-to-PDF conversion, Nutrient addresses font licensing constraints through font substitutions, typically replacing unavailable fonts with their equivalents — like Arial with Noto. For precise font matching, you can provide your own fonts, embed them into source files, or designate paths to your .ttf fonts for custom solutions.

Adding even more capabilities

Once you’ve deployed your viewer, you can start customizing it to meet your specific requirements or easily add more capabilities. To help you get started, here are some of our most popular Vue.js guides:

Conclusion

In this blog post, you learned how to build an Excel viewer using Vue.js with the Nutrient SDK. It also discussed the benefits of using Nutrient Web SDK to render Office documents in the browser. If you hit any snags, don’t hesitate to reach out to our Support team for help.

You can also integrate our JavaScript Excel viewer using web frameworks like Angular and React.js. To see a list of all web frameworks, start your free trial. Or, launch our demo to see our viewer in action.

FAQ

Here are a few frequently asked questions about building an Excel viewer.

What is Nutrient Web SDK, and how does it help with Excel file viewing?

[Nutrient Web SDK][] is a JavaScript library that converts Office documents, including Excel files, to PDF directly in the browser, allowing for advanced viewing and interaction without requiring MS Office software.

How can I integrate Nutrient Web SDK into my Vue.js project?

Integrate Nutrient Web SDK by installing the pspdfkit package via npm or yarn, adding it to your Vue.js project, and initializing it in your Vue component using PSPDFKit.load().

What are the main features of the Excel viewer built with Nutrient Web SDK?

The Excel viewer supports rendering XLS and XLSX files, allows text editing, page manipulation, annotations, and adding signatures directly within the viewer.

How do I handle different Excel files in the Vue.js viewer application?

Use a file input element to upload Excel files, which are then rendered using Nutrient by creating an object URL for the selected file and passing it to the Nutrient component in your Vue.js application.

Author
Hulya Masharipov Technical Writer

Hulya is a frontend web developer and technical writer at Nutrient who enjoys creating responsive, scalable, and maintainable web experiences. She’s passionate about open source, web accessibility, cybersecurity privacy, and blockchain.

Related products
Share post
Free trial Ready to get started?
Free trial