.. and press ENTER to ask a question on web5, how to write code and more.

Skip to main content

Vue

Setting up the Web5 SDK in a Vue or NuxtJS project.

If the suggested steps here don't work, please open an issue or post your questions in the #web5 channel on TBD Discord.

Create your project​

You can add Web5 to an existing Nuxt or Vue project, or create a new one with the Vue CLI:

npm create vue@latest

Install the Web5 SDK via NPM​

npm install @web5/api

Update your package.json​

Add module as a type to your package.json:

{
"dependencies": {
"@web5/api": "0.12.0"
},
"type": "module"
}

Add the Web5 import to your Vue app​

Then, add the plugin to your Vue app:

app.vue
import { Web5 } from "@web5/api";

Use Web5 as a global plugin in NuxtJS​

If you're building a multi-page website, you want to avoid calling web5.connect() on every page. Instead, you can use Web5 as a global plugin in NuxtJS.

plugins/web5.client.js
import { Web5 } from '@web5/api';

export default defineNuxtPlugin({
async setup (nuxtApp) {
let web5;
let myDID;

({ web5, did: myDID } = await Web5.connect());

return {
provide: {
web5,
myDID
}
};
},
});

You can use this plugin in your Nuxt page as;

pages/index.vue
<script setup>
const { $web5: web5, $myDID: myDID } = useNuxtApp();

console.log(web5, myDID);
</script>

Address polyfill errors​

Sometimes, you may get errors where the Web5 SDK isn't initializing in your client app e.g process.nextTick is not a function. This is usually because some polyfills are missing. To solve this;

  • Install the vite-plugin-node-stdlib-browser plugin:
npm install vite-plugin-node-stdlib-browser --save-dev

If you are using Nuxt, add this to your nuxt.config.js file:

nuxt.config.ts
import nodePolyfills from 'vite-plugin-node-stdlib-browser';

// https://nuxt.com/docs/api/configuration/nuxt-config
export default defineNuxtConfig({
devtools: { enabled: true },
ssr: false,
vite: {
plugins: [nodePolyfills()],
},
})

Then add the following to your vite.config.js file:

vite.config.js
import { defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
import nodePolyfills from 'vite-plugin-node-stdlib-browser';

// https://vitejs.dev/config/
export default defineConfig({
build: {
target: ['chrome109', 'edge112', 'firefox102', 'safari15.6', 'ios15.6']
},
define: {
global: 'globalThis'
},
plugins: [vue(), nodePolyfills()],
});

If you run into any errors, check out our troubleshooting guide for a possible solution.

Uncaught ReferenceError: xxxx is not defined​

With the latest Nuxt releases, there seems to be a transpiling error when trying to deploy Nuxt with npm run build. If you get an error like Uncaught ReferenceError: require is not defined, you can fix it by adding the following to your nuxt.config.js file:

nuxt.config.js
export defineConfig({
vite: {
build: {
commonjsOptions: { transformMixedEsModules: true }
}
}
});

If the error isn't fixed, then try downgrading your Vue / Nuxt version to lower than you currently have it.

Connect with us on Discord

Submit feedback: Open a GitHub issue

Edit this page: GitHub Repo

Contribute: Contributing Guide