Nuxt.js presets all the configuration needed to make your development of a Vue.js application enjoyable. Nuxt’s very opinionated when it comes to code structure. Its conventions can save you a lot of time making decisions. In this article, you will see 7 nuxt tips for beginners.
This remains a quick, useful hack. I say hack because I learned the proper way to do it is by using Nuxt’s router module. Still, if you don’t need full access to VueRouter’s features, extendRoutes() gets the job done.
Tying Nuxt’s loading component to HTTP request activity is probably not as efficient as simply disabling it on individual pages and manually controlling it with start()
and finish()
. The ability to set the loading
property to false
in order to disable it in a page came in the 2.0 release and was my very first contribution to the project:
export default {
loading: false,
async mounted() {
await this.$http.$post('/init')
this.$nuxt.$loading.finish()
}
}
In this example, setting loading
to false
would keep the **Nuxt **loading component active upon entering the page, giving you the chance to manually stop it. This is, of course, assuming it was already started by a previous route, automatically or manually via the start()
method. That is to say, if you set loading
to false
on a page, you will also have to manually start()
the Nuxt loading component before navigating to a different route.
Another pattern I’ve seen myself using frequently is updating the **Vuex **store with the status of the Nuxt loading component. This way I can easily use it to update specific pieces of the **UI **that may complement it visually.
export default {
computed: {
loading: {
get() {
return this.$store.state.loading
},
set(status) {
this.$store.commit('updateLoadingStatus', status)
}
}
},
methods: {
start() {
if (this.loading) {
return
}
this.loading = true
},
finish() {
if (!this.loading) {
return
}
this.loading = false
}
}
}
I no longer recommend using Nuxt as Koa middleware. I have learned Nuxt’s built-in HTTP server is more than capable for the same type of workloads you would expect Koa to handle. If you’re using different processes for your backend API and Nuxt application code (recommended) and still want to use a Node-based API server, I’d look at hapi, polka or micro. We’re also releasing @nuxt/metal soon, which builds on connect.
When using Nuxt server middleware, the same technique of adding things to the req
or res
objects that are passed to a middleware handler applies.
I’ve stopped doing this altogether. Nuxt now allows you to break down Vuex store modules in separate files like state.js, actions.js, and mutations.js. It’ll recognize all files that match these expected Vuex properties (including getters
) and use them to build a store module. This makes code organization a lot easier and natural.
You probably want to check out unholy though, a Nuxt module I wrote that changes Vuex’s default commit()
behavior to accept a single parameter: an object to be deeply merged with the root state. A source close to the Vue core team has hinted a similar feature might be added to Vuex itself.
You’re probably better off using the build.templates configuration option. They allow you to add a list of Nuxt template files (that are automatically preprocessed by <a href="https://lodash.com/docs/4.17.11#template" target="_blank">lodash.template</a>
). Instead of manually using writeFileSync()
, you can just specify source, destination and an object with options (template variables), as follows:
export default {
build: {
templates: [{
options: { api: getAPITree() },
src: './src/api.js.template',
dst: `../src/api.js`
}]
}
}
I’ve changed the setup for this. Instead of using my old utility-based approach, I now use a client-side plugin to add an onNuxtReady
handler. I usually import it from src/ready
as follows:
import ready from '~/ready'
window.onNuxtReady(ready)
You can have this in a file named ready.client.js
and list it under the plugins
configuration option. Nuxt will understand that this is a plugin to be run client-side only, sparing you from having to check for process.client
every time.
As I’ve covered towards the end of my article, Nuxt: The Hard Parts, @nuxtjs/axios is no longer the recommended HTTP client library for Nuxt applications. The API for interceptors using @nuxt/http is similar and remains a feature used in every one of my Nuxt projects.
The main difference when using @nuxt/http
interceptors is that you’re required to use the set(key, value)
method of a preexisting config.headers
object, instead of simply assigning keys to it. Here’s the updated example:
export default function ({ $http }) {
$http.onRequest((config) => {
config.headers.set('Authorization', `Bearer ${token}`)
return config
})
}
#nuxt-js #vue-js #javascript