Skip to content

Update dependency nuxt to ^2.17.1

This MR contains the following updates:

Package Type Update Change
nuxt devDependencies minor ^2.2.0 -> ^2.17.1

MR created with the help of gitlab-org/frontend/renovate-gitlab-bot


Release Notes

nuxt/nuxt

v2.17.1

Compare Source

2.17.1 is the next patch release for Nuxt 2.

👉 Changelog

compare changes

🩹 Fixes
  • webpack: Downgrade dev-middleware to fix peer dep issue (#​21626)
  • webpack: Pin webpack-dev-middleware to 5.0.0 (#​21804)
️ Contributors

v2.17.0

Compare Source

2.17.0 is the next minor release for Nuxt 2.

Highlights

Nuxt 2.17 comes with a few new features, including better support for new Vue 2.7 types, and supporting passing postcss config as a function.

It also includes support for Node 20+ and a fix for a dependency issue with the Babel preset that affected new installs.

👉 Changelog

compare changes

🚀 Enhancements
  • types: Support nuxt types for defineComponent (#​19789)
  • csp: Support generating nonce for scripts and links in ssr (#​9621)
  • webpack: Support passing function as postcssOptions (#​19495)
🔥 Performance
  • config: Avoid recursive md4 patching (7fab95252)
🩹 Fixes
  • Relax node engines upper constraint (010b539ed)
  • utils: Respect patterns within paths when sorting routes (#​20669)
  • vue-app: Skip page render early on error or navigation (#​20719)
  • babel-preset-app: Add explicit dep on used babel plugin (#​21488)
🏡 Chore
  • Reenable publishing 🙈 (4ce8b118e)
  • Exclude yaml exception vulnerability (build-time dep) (c8ed87a26)
  • Bump jest dependencies (#​20506)
  • Remove resolved advisories (98cd35665)
  • Skip publishing node_modules folder (8799cfacc)
  • Remove obsolete useWorkspaces option (27e450119)
Tests
  • Add catchall path to route generation test (71c359516)
  • Update windows snapshot (4ec274ae2)
  • Update jest snapshots to remove escaped quotes (f93411c7c)
🤖 CI
️ Contributors

v2.16.3

Compare Source

2.16.3 is a patch release with bug fixes.

👉 Changelog

compare changes

🩹 Fixes
  • types: Add return type for error() (#​19044)
  • types: Bring types from less into namespace (#​19738)
  • types: Sync vue type augmentations with Vue 2.7 (#​19526)
  • config: Move preset to inner postcssOptions (#​19518)
  • webpack: Add node-fetch-native to externals list (#​19755)
🏡 Chore
  • Release all packages with latest tag except nuxt (4e9dcddcb)
  • examples: Use 2.x version of nuxt instead of latest (#​19737)
  • Lint package files (6ca842e36)
️ Contributors

v2.16.2

Compare Source

2.16.2 is a patch release with bug fixes.

Highlights

The main change in this patch release is that we now patch the crypto node built-in during build to allow Nuxt 2 to be used on Node versions greater than Node 16, which should ease the pressure users feel after Node 16 reaches its own EOL this year.

Warning This should not be taken for an endorsement of continuing to run with Webpack 4, which is out of date and has a number of dependencies with issues. I expect that number to continue to grow, and we will not be able to resolve all of them. I would strongly urge migrating to Nuxt 3 if possible and the team will do our best to make this possible over the course of the year

👉 Changelog

compare changes

🚀 Enhancements
  • types: Add basic types for Nuxt interface (#​9772)
🩹 Fixes
  • vue-renderer: Insert charset before title (#​18998)
  • types: Remove non-existent properties from context (#​19021)
  • Add minimum node 14.18 version constraint (#​19112)
  • config: Upgrade md4 -> md5 on node > 16 (#​19108)
  • vue-app: Handle promise rejection from asyncData (#​18585)
🏡 Chore
️ Contributors

v2.16.1

Compare Source

Nuxt 2.16.1 is a patch release with a couple of small bugfixes to last week's 2.16.0 release.

v2.16.0...v2.16.1

🩹 Fixes
  • deps: Downgrade @types packages depending on webpack 5 (#​18827)
  • config: Let webpack merge postcss plugins (#​18839)
  • types: Import Location from vue-router (#​18908)
🏡 Chore
  • Tag 2.x releases appropriately (aba93e9)
  • Revert node types to v16 (3d034a3)
  • Remove stub type definitions (daed62a)
️ Contributors

v2.16.0

Compare Source

Nuxt 2.16.0 is the first minor release since Feb 15, 2021. The focus is mostly on releasing the latest fixes and enhancements that have been present in nuxt-edge for some time.

Highlights

️ Breaking changes

  • In this MR we only support Node 14+. This is mostly an issue for dependencies, which we need to keep updated for security reasons. Going forward until its own EOL, Nuxt 2 will only officially support Node versions that have not reached their EOL.

  • New postcss options format. See https://github.com/nuxt/nuxt/pull/9671 for full details.

  • Dependency upgrades. A number of dependencies have dropped support for earlier node versions. dotenv has changed how it parses .env files in a number of edge cases. glob now requires / instead of \ on windows machines. There may also be other changes that affect your usage, so please do upgrade with care.

  • Vue 2.7 upgrade. Although you can use Vue 2.7 with any release of Nuxt 2, 2.16.0 for the first time includes it as a dependency, which means that you may well encounter some issues associated with upgrading Vue 2.6 -> Vue 2.7.

    This may be a good time to consider using the composition API utilities provided by https://github.com/nuxt/bridge instead, which mirror Nuxt 3's more precisely than @nuxtjs/composition-api. (You can opt-in to just these utilities by disabling the other bridge modules individually.)

Changelog

compare changes

🚀 Enhancements
  • config: Support nuxtrc in dist directory (#​9280)
  • generator: Add ignoreEnv generate option during ensureBuild(cmd) (#​8955)
  • server: Allow disabling serve-static middleware (#​9365)
  • types: Add asyncData return types to component instance type (#​9239)
  • vue-app: context.beforeSerialize method (#​9332)
  • vue-app: Pass store to createRouter (#​9629)
  • Default to core-js version 3 (#​9987)
  • webpack: ️ Update postcss to v8 (#​9671)
🩹 Fixes
  • vue-app: Respect scroll-margin-top when navigating with hash (#​9187)
  • webpack: Use javascript/auto for js rule (#​9180)
  • server: Unregister error event listener (#​9245)
  • babel-preset-app: Respect explicit options.targets for modern preset (#​9337)
  • types: Add nuxt.config alias type (#​9424)
  • vue-app: Check whether route exists within nuxt app before replacing (#​9431)
  • vue-renderer: Decode route path for payload.js (#​9494)
  • vue-app: Don't normalise route path if it's valid (#​9460)
  • vue-app: Redirect to external url replaces current history entry (#​9500)
  • utils: trailingSlash causes error with dynamic nuxt-child routes (#​9505)
  • types: Add onNuxtLoaded and onNuxtReady types (#​9510)
  • vue-app: Re-register components construtor in HMR (#​9539)
  • types: Add typing for build.stats options (#​9555)
  • babel: Loose option for babel private-property-in-object (#​9631)
  • vue-app: Serialize route meta to allow functions (#​9634)
  • vue-app: null check for $root access (#​9150)
  • generator: Allow passing builder to getGenerator (#​9574)
  • generator: Throw an error when Builder is missing (#​9663)
  • vue-app: Use correct $config for finding basePath (#​9706)
  • vue-renderer: Ensure custom build indicator preserves some whitespace (#​9705)
  • 'npm run test' fails because the last command lacks 'yarn' (#​9761)
  • generator: Decode path with ufo (#​9739)
  • cli: Ensure nuxt instance is closed when skipping build (3e9d7e3)
  • Nuxt-child-key in web-types.json (#​9792)
  • types: Return type of $fetch (#​9854)
  • deps: Update ua-parser-js to 1.x (#​9979)
  • deps: Update ya-parser-js to latest 0.7.x (#​9979)
  • vue-app: Call ssrContext.unsetMutationObserver only if it exists (#​10132)
  • webpack: Allow files with .cjs extension to be transpiled (#​10340)
  • vue-app: Preview mode fetch (#​10489)
  • webpack: Resolve .wasm extension with lower priority (#​10676)
  • vue-app: Clear hide timeout when calling clear() (#​10086)
📦 Build
🌊 Types
  • Add prefetchPayloads to router options (#​9715)
🏡 Chore
  • release: V2.15.6 (a53fd32)
  • pkg: Build for es2019 target (#​9328)
  • types: Add types for new false option for render.static (#​9372)
  • Update error tests (d4e5998)
  • test: Revert jest and babel-jest to 26 (#​9377)
  • Ignore audit 1754,1755 (39f7859)
  • Fix vetur extension syntax for GitPod (#​9572)
  • Ignore globby > 12 upgrade as needs native esm (e0968a3)
  • Update rollup plugins (5614399)
  • Fix code formatting (17bbb21)
  • utils: Improve stripWhitespace utility (#​9668)
  • Update license year to present (#​9682)
  • Add separate file with security disclosure info (#​9738)
  • Update logo (#​9796)
  • doc: Fix link to contribution guide (#​9815)
  • test: Fix external redirect link (#​9816)
  • Update funding.yml (1f85137)
  • Update lockfile (7614360)
  • Update audit list (6f73c36)
  • Update lockfile and audit (1878b26)
  • Update issue template with nuxt 3 (#​9948)
  • Enable blank issues (54542c1)
  • radme: Fix browserstack and saucelabs icons (#​10068)
  • Update dependencies (#​10510)
  • Update repo (773d292)
  • Ignore vue and vuex major updates (bafc814)
  • Update README.md (#​10831)
  • Update pull request template (0db7e7b)
  • Update issue templates (f36fb9c)
  • Rename 2.x bug template (ba966cf)
  • Move nuxt 2 report to bottom (ce7b1a9)
  • Bump ua-parser-js version (1cedad5)
  • Bump test/dev dependencies (#​18672)
  • Upgrade unjs dependencies (#​18670)
  • Use named export from defu (#​18679)
Tests
🤖 CI
️ Breaking Changes
  • webpack: ️ Update postcss to v8 (#​9671)
️ Contributors

v2.15.8

Compare Source

🐛 Bug Fixes
  • vue-app
    • #​9460 Don't normalise route path if it's valid
  • babel
    • #​9631 Loose option for babel private-property-in-object

v2.15.7

Compare Source

🔰 Security advisory

Please upgrade to nuxt@^2.15.7 if using nuxt@2.15.5 or nuxt@2.15.6

🐛 Bug Fixes
  • vue-app
    • #​9431 Check whether a route exists within the nuxt app before replacing

v2.15.6

Compare Source

🐛 Bug Fixes

v2.15.5

Compare Source

🐛 Bug Fixes
  • babel
    • #​9232 Loose option for babel class-properties and private-methods (resolves #​9224)
  • vue-app
    • #​9201 Use route.replace instead of router.push to trigger navigation guards (resolves #​9111)
  • builder
  • cli
💖 Thanks to

v2.15.4

Compare Source

🐛 Bug Fixes
👕 Types
💖 Thanks to

v2.15.3

Compare Source

🐛 Bug Fixes
  • types
    • #​8953 Export interface for NuxtConfig instead of type
  • webpack
    • #​8951 Update hmr option for extract-css-chunks-webpack-plugin
  • general
    • #​8936 Allow force overriding resolve paths
    • #​8935 Allow relative public paths
    • #​8887 Update @babel/preset-env to 2.13.x
  • vue-renderer
    • #​8912 Respect injectScripts for static target
💖 Thanks to

v2.15.2

Compare Source

🐛 Bug Fixes
💖 Thanks to

v2.15.1

Compare Source

🐛 Bug Fixes
  • renderer
    • Deep merge runtime config for server (resolves #​8820)
  • webpack
  • cli
    • #​8841 Don't early return when a dependency isn't installed
  • types
    • #​8835 build.html.minify can be false
  • builder
    • #​8832 Use path.resolve for pages dir
💖 Thanks to

v2.15.0

Compare Source

💡 Highlights

️This release introduces behavior changes. Update with caution

or

npm i --save-dev css-loader@^5.0.0 postcss@^8.1.10 postcss-import@^13.0.0 postcss-loader@^4.1.0 postcss-url@^10.1.1
```
  • Several encoding issues resolved by consistently using ufo
  • Components updated to v2 (please read migration guide)
  • [Modules] When matching a webpack loader by name or query, should use includes instead of exact match (example)
🐛 Bug Fixes
  • general
    • #​8794 Ignore trailing slash in static payloads manifest
    • #​8738 Encoding issues with payload paths
    • #​8423 trailingSlash and child routes not working
  • config
    • #​8778 Prevent invalid css filenames in webpack output
  • utils
    • #​8780 serializeFunction fails with certain functions
  • vue-app
    • #​8759 Enable dynamic publicPath on server-side
    • #​8701 Static payload fetching bugfixes
    • #​8612 Check for Page.options before looking within
    • #​8611 Don't remove req, res and query from context unless in full static mode
    • #​8608 Ensure link.__prefetch exists before calling it
    • #​8596 Add missing id attribute to noopApp
    • #​8557 Scroll-to-top on route changes only
    • #​8523 Set push on router instance rather than prototype
    • #​8486 Do not preserve state when registering client-side dynamic module
    • #​8802 Add leading slash for payload hydration
  • server, vue-app
    • #​8748 Address encoding issues with query params
  • dev
    • #​8697 Clearnup vue installed plugins from server in dev mode
    • #​8556 Resolve module required by create-require in jiti
  • cli
    • #​8683 Disable parallel build behaviour when generating
  • webpack
    • #​8555 Can't resolve absolute url in css
  • server
    • #​8593 Fix HMR issue with serverMiddleware when router.base is set
  • babel
    • #​8545 Enable polyfilling of proposal core-js features
  • vue-app, vue-renderer, utils
    • #​8489 Respect trailingSlash setting for payloads
  • generator
    • #​8474 Ensure static manifest dir exists
    • #​8803 Normalize trailing slashes before extendRoutes
🚀 Features
  • cli
    • #​8792 Warn if incompatible node and package versions detected
  • postcss
    • #​8546 Support postcss v8 with explict postcss installation
  • config, vue-app, vue-renderer
    • #​8520 Support dynamic base and publicPath
  • general
    • #​8389 Support plug-and-play, typescript runtime and native modules
    • #​8346 Update all dependencies that require node 10.x
  • vue-app
    • #​8466 Support custom fetchKey for full static generation
  • vue-renderer
    • #​8347 Allow adding async attribute to <script> tags
💅 Refactors
  • utils, vue-app
    • #​8765 Use ufo to parse queries and join urls
  • vue-app
    • #​8621 Simplify scrollToTop checking
  • general
    • Consistent behavior for resolveModule
🏡 Chore
🇹 Types
  • #​8784 Add missing ssr option to config types
  • #​8767 vue.config types should be optional
  • #​8530 Add missing redirect overload to Context interface
  • #​8638 Add enablePreview to context
  • #​8648 Add missing loadingScreen type definition
💖 Thanks to

And all nuxters helping everyday with valuable feedbacks 💚

v2.14.12

Compare Source

🐛 Hot Fixes

How to upgrade?

Use yarn upgrade nuxt or npm up nuxt

v2.14.11

Compare Source

🐛 Hot Fixes

v2.14.10

Compare Source

🐛 Hot Fixes

v2.14.9

Compare Source

🐛 Hot Fixes
  • #​8421 Only encode non dynamic path params

v2.14.8

Compare Source

🐛 Bug Fixes
  • webpack
    • #​8205 Allow transpiling packages in nested node_modules
  • general
    • #​8325 Handle route encodings and update vue-router
  • vue-router
    • #​8394 Force chidren to be required if default child is present (resolves #​7823)
  • cli
    • #​8398 Respect router.trailingSlash when serving static files (resolves #​8350)
    • #​8337 Handle generate.cache.ignore as a function in ensureBuild
  • generator
  • csp
  • vue-app
    • #​8314 Handle missing payloads on full static (resolves #​7717)
    • #​8348 Warn if promises and functions are in fetch state (resolves #​8338)
    • #​8225 TriggerScroll when transitions is disabled
    • #​8289 Use nuxt globalName correctly in nuxt-link and fetch mixin (resolves #​8118)
    • #​8280 Prevent redirection loop with URI-encoded path (resolves #​8116)
  • types
    • #​8362 Correct vue.config types
    • #​8349 Add missing isFetching and nbFetching to NuxtApp interface
    • #​8319 NuxtOptionsHead can be a function
    • #​8302 Add missing ssrContext and next typings to Context (resolves #​8296)
  • server
    • #​8313 Redirect if router.base specified in development
💅 Refactors
👓 Tests
💖 Thanks to

v2.14.7

Compare Source

🐛 Bug Fixes
  • babel-preset-app
    • #​8203 Always transpile optional chaining and nullish-coalescing for server
  • cli
    • #​8200 Rebuild if process.env changes in nuxt.config
    • #​8194 Avoid error about nuxt-edge if installed in parent node_modules
    • #​8134 Mode deprecation with explicit spa or universal flag
  • vue-app
    • #​8170 Use getter to provide this.$nuxt
    • #​8055 ScrollRestoration hasn't set
  • types
    • #​8182 Add type for serverMiddleware object format
    • #​8169 Make NuxtConfig an interface
  • generator
    • #​8166 Handle when no routes.json defined
  • general
    • #​8206 Add better logs for DX with target option
💖 Thanks to

v2.14.6

Compare Source

🐛 Bug Fixes
💖 Thanks to

v2.14.5

Compare Source

🐛 Bug Fixes
💅 Refactors
🇹 Types
💖 Thanks to

v2.14.4

Compare Source

🐛 Bug Fixes
  • vue-renderer
  • cjs
    • #​7938 Fix HMR issue with mongoose (resolves #​7917)
    • #​7966 Protect clearRequireCache against infinite recursion
  • cli
    • #​7948 Handle nuxt generate with --fail-on-error for static target (resolves #​7947)
  • vue-app
  • webpack
🏡 Chore
💖 Thanks to

v2.14.3

Compare Source

🐛 Bug Fixes
  • vue-renderer
    • #​7928 Apply nomodule to legacy chunks
💖 Thanks to

v2.14.2

Compare Source

🐛 Bug Fixes
  • webpack
  • modern
  • vue-app
    • #​7877 Use anchor to / if route is undefined in error page (resolves #​7841)
    • #​7920 Fix vue-router@2.14 regression with scrollToTop
    • #​7916 Prevent router.registerModule reallocation (resolves #​7915)
  • router
    • #​7912 Use updated error codes to fix redirect errors
  • cli
    • #​7860 Improve project dir detection for external commands
👕 Types
  • general
    • #​7902 Improve definitions for component transition property
💖 Thanks to

v2.14.1

Compare Source

🐛 Bug Fixes
📝 Examples
  • tailwindcss-purgecss
    • #​7800 Update tailwindcss from 0.6 to 1.6 using purgecss
🏡 Chore
💖 Thanks to

v2.14.0

Compare Source

Highlights
🚀 Features
  • webpack
  • builder
  • general
  • vue-renderer
    • #​7633 Add vue-renderer:spa:prepareContext hook
  • vue-app
    • #​7611 Add web-types.json for better code insight in WebStorm
🐛 Bug Fixes
  • webpack
    • #​7787 ensure loaders are first searched from @nuxt/webpack
    • #​7763 font-family hex issue
    • #​7667 Fallback for empty chunk name
  • vue-app
    • #​7766 nuxt-link prefetch error on fallback page
    • #​7718 Handle fallback on generated page
    • #​7723 Don't fetch payload for store mutation for preview and spa fallback
  • generator
    • #​7776 Avoid duplicate slashes for routes ending with hash
  • cli
    • #​7775 Don't use absolute path of .cache/nuxt as transpilation pattern
  • utils
    • #​7761 Include routes with children for generation
  • vue-renderer
    • #​7752 Read target from class instead of serverContext
  • router
    • #​6594 Show default child if trailingSlash is false
🖤 Refactors
  • server
    • 5272a4 Rename externalsWhitelist to externalsAllowlist
📝 Examples
  • vuetify
👕 Types
  • general
    • #​7670 Fix module options type
    • #​7709 Add cross-origin property to NuxtOptionsRender
    • #​7670 Fix module options type
💖 Thanks to

v2.13.3

Compare Source

🐛 Bug Fixes
💅 Refactors
  • csp
    • #​7659 Remove unsafe-eval in dev mode
📝 Examples
  • with-sockets
    • #​7650 Deprecated callback and use cjs
  • with-vuetify
    • #​7638 Use v-main instead of v-content
👕 Types
  • general
    • #​7626 Import types for @nuxt/telemetry and @nuxt/components
💖 Thanks to

v2.13.2

Compare Source

🐛 Bug Fixes
  • webpack
  • core
  • cli
  • vue-app
  • utils
    • #​7604 Flat routes if child routes have absolute paths
Dependencies
💖 Thanks to

v2.13.1

Compare Source

🐛 Bug Fixes
👕 Types

v2.13.0

Compare Source

What's new?
  • New target: static and full static using nuxt export
  • Built-in .env support and runtimeConfig
  • Auto components discovery with nuxt/components
  • Nuxt Telemetry

Also don't miss nuxt/content and nuxt-composition-api ;)

🚀 Features
🐛 Bug Fixes
  • core
    • #​7267 Improve module not found error
    • #​7131 Join with os native sep in resolver
  • general
  • webpack
    • #​7462, #​7464 Reduce false negatives in nodeExternals
    • #​7318 Allow HMR client path to be set
    • #​7305 Use non-eval sourcemap with csp and unsafe-eval script policy
  • vue-app
    • #​5703, #​7442 Prevent double layout execution
    • redirect no longer strips trailing slash from URL (#​7475, #​7533)
    • #​7162 Allow background customization for default loading template
    • #​7271 sanitizeComponent import regression with features disabled
    • #​7139 Sanitize layouts after resolve for splitChunks.layout
  • generator
    • #​7335 Improve error handling when build does not exists
  • modern
    • #​7498 Modulepreload not work in generate
    • #​7382 Wrong assets mapping in ssr client modern mode
  • vue-renderer
    • #​7439 Fix meta injection when ssr renderer generates a spa page
    • #​7376 Base tag should be before any link or script tag
  • generator, builder
    • #​7361 Empty build and dist directories instead of remove
  • babel
    • #​7297 Not override presets if babelrc is true
  • server
    • #​7146 HMR for sub-app serverMiddleware without path
💅 Refactors
  • general
  • config
    • #​7187 Move build.crossorigin to render.crossorigin
📝 Examples
  • with-buefy
🏡 Chore
  • cli
  • general
  • renovate
    • Ignore @types/terser-webpack-plugin
  • pkg
    • #​7373 Update rollup and dependencies
  • dep
    • #​7119 Upgrade html-webpack-plugin to v4
  • test
  • benchmark
  • example
👓 Tests
💙 Types
  • general

    • #​7432 Move @nuxt/types to nuxt mono-repo
💖 Thanks to

v2.12.2

Compare Source

🐛 Bug Fixes
  • server
    • #​7146 HMR for sub-app serverMiddleware without path
  • vue-app
    • #​7139 Sanitize layouts after resolve for splitChunks.layout
  • core
    • #​7131 Join with os native sep in the resolver

v2.12.1

Compare Source

🐛 Bug Fixes
  • vue-app
    • #​7129 Avoid multiple $fetch calls
    • #​7103 Use globals.nuxt for fetch client mixin
    • #​7128 Set default name to layout to avoid multi mounted calls
  • builder
    • #​7097 Ensure entry is in the graph for HMR
🏡 Chore
  • readme
    • #​7092 Simplify readme and add gitpod in contributing section
  • examples
    • #​7098 Avoid warning with legacy postcss.config.js
💖 Thanks to

v2.12.0

Compare Source

🚀 Features
  • general
    • #​6950 Support crossorigin attribute in SSR script and preload tags
    • #​6868 Improve programmatic usage (see docs)
    • #​7029 Expose webpack config
    • #​6272 Allow disabling loading-screen
  • webpack
    • #​6987 Support @import using ~assets in css files
    • #​6272 Allow disabling loading-screen
  • vue-app
    • #​6880 New fetch syntax (see docs)
    • #​6939 Pass error as param to nuxt-loading fail method
    • #​6244 Trigger watchParam when param is changed in same route
  • cli
    • #​6855 Pass context when nuxt.config exports a function
👌 DX
  • builder
    • #​6924 Analyze mode warning rewording
  • general
  • generator
    • #​6882 Log message or full error for unhandled error without stack trace
  • cli
    • #​6904 Display listening URLs after build
  • vue-app
    • #​7032 Improve missing inject value error message
    • #​6775 Middleware not executing on double browser back navigation
  • core
    • #​7079 Better module not found handling
🔥 Performance
  • vue-renderer
    • #​6973 Early return render when redirect happens
    • #​6846 Don't serialize session when injectScripts is false
🐛 Bug Fixes
  • core
    • #​7002 Deprecated render:context and render:routeContext hooks was not being called
  • babel-preset-app
    • #​7070 TypeError when import cjs in webpack building
  • vue-app
    • #​6946 Use child transition name when navigating to parent
    • #​6854 Add fallback context for errors
    • #​6803 Resolve leave transition on child routes
    • #​6807 Move head to the index to avoid global state
  • webpack
    • #​6864 Provide global URL and URLSearchParams
💅 Refactors
  • general
    • #​6954 Use scope variable memo for modern utils
  • utils
    • #​6953 Eliminate side effect from modern utils
📝 Examples
  • cached-components
🏡 Chore
  • general
    • #​6816 Simplifies Code Contributions & Reviews
  • ci
👓 Tests
  • general
    • Fix socket-hang-up test
    • Separate dev and unit test
    • Avoid unexpected outside stderr assertion count
    • Fix uncompressed resource size
    • Wrap error test with consola to make output clear
💖 Thanks to

v2.11.0

Compare Source

🐛 Bug Fixes
  • utils
    • #​6777 Add catch statement to non function block in serializeFunction
    • #​6791 Fix flatRoutes regex for nested routes with trailing slash enabled
  • vue-app
    • #​6658 Pass router mode to getLocation
    • #​6683 Apply path-to-regexp options to tokensToFunction
    • #​6650 Layout in error.vue not work for Vue.extend component
    • #​6623 Add prefetched class to <nuxt-link> after chunk loaded
  • general
    • #​6685 context.route issue in plugins and splitChunks.pages === false
    • #​6590 Collapsed SSR log
  • webpack
    • #​6495 Enable devtool for dev mode
    • #​6566 Normalize devtool for terser compatibility
  • config
    • #​6583 Typo in unsafeInlineCompatibility name
🚀 Features
  • vue-app
  • general
    • #​6149 Optionally strip non-client or non-server code
  • vue-renderer
    • #​6505 Support evaluation in templates
  • config
    • #​6597 Add ignoreOptions for node-ignore
💅 Refactors
  • server
    • #​6771 Only append not empty allowed sources to csp
🔥 Performance
  • webpack
📝 Examples
  • with-sockets
    • #​6586 Fix cannot read property 'app' of undefined on nuxt build
🏡 Chore
  • general
    • #​6732 Update @nuxtjs/eslint-config to v2 and fix lint errors
    • #​6686 Fix typo in middleware readme
    • #​6649 Limit stale bot to only issues
    • #​6637 Remove unused dependencies
    • #​6630 Use .github/config.yml for issue template
  • docs
  • ci
    • #​6739 Remove coverage collection in fixtures
    • #​6747 Use LTS Node.js instead of latest
    • #​6737 Separate dev test and unit test
  • github
    • #​6657 Add chinese translation for issue template
👓 Tests
💖 Thanks to

v2.10.2

Compare Source

🐛 Bug Fixes
  • webpack
    • #​6495 Enable devtool for dev mode
    • #​6566 Normalize devtool for terser compatibility
  • config
    • #​6583 Typo in unsafeInlineCompatibility name
  • vue-app
📝 Examples
  • with-sockets
    • #​6586 Fix cannot read property 'app' of undefined on nuxt build
💖 Thanks to

v2.10.1

Compare Source

🐞 Fixes
  • vue-app, webpack
  • utils
    • #​6515 Fix error when router.trailingSlash is false
  • generator
    • #​6362 Remove trailing slash when no subFolders are used
  • webpack
    • #​6520 chunkhash and contenthash not work with extractCSS
  • cli
    • #​6525 Enable server for nuxt build when pages should be generated
🏡 Chore
  • readme
    • #​6511 Remove deprecated starter template
Dependency Upgrades
  • vue-meta: Upgraded to v2.3 which fixes duplicated tags in SPA mode
💖 Thanks to

v2.10.0

Compare Source

🌟Highlights
  • Support for improved typescript runtime
  • Experimental support for feature toggling for SUPER slim builds!
  • Mitigate problems with nuxt server stocking during development
  • Fix issues with internet-explorer in development mode
  • Upgrade to terser webpack plugin v2
  • Improved stability of loading-screen. No more endless loops (nuxt/loading-screen#​44) and show fatal errors (nuxt/loading-screen#​45) for the initial build
🐛 Bug Fixes
  • core
    • #​6490 Clear resolver cache for project files dev mode
  • vue-app
    • #​6479 Error page layout not correctly applied in client-side rendering
    • #​6473 Pass vm as arg to support data() with arrow function
    • #​6433 Fix asyncData hydration when features.transition is false
    • #​6430 Clear idle callback
    • #​6217 Prevent looping on error during render of error page
  • webpack
    • #​6298 Fix consola IE compatibility
    • Revert pause/resume
    • #​6460 Correct sass options for sass-loader@8
    • #​6448 Don't push to compilersWatching in callback
  • cli
    • #​6441 Server should not be initialized in nuxt build
  • babel-preset-app
    • #​6435 Use loose mode for babel class plugin
  • vue-renderer
  • config
    • #​6371 Enable total timing by default when server.timing is enabled
  • config, vue-app
    • #​6379 Add module declaration for config and vue-app
🚀 Features
  • cli, config
  • config
    • #​6414 serverMiddleware as a simple key/value object
  • builder
    • #​6368 followSymlinks option to allow for symlinks
    • #​6285 extendPlugins option and builder:extendPlugins hook
    • #​6329 Add builder:prepared hook
    • #​6342 Support adding custom middleware
  • cli
    • #​6475 Catch build errors with cli:buildError hook
  • webpack
    • #​6477 Use vue-meta browser build for client bundle
    • #​6398 Upgrade terser-webpack-plugin to v2
    • #​6350 Add webpack:config hook
  • server
    • #​6438 Add config option to define etag hash function
  • vue-app
  • general
    • #​6432 Support setting (non-essential) vue-meta options by user
  • utils
  • builder, router
    • #​6331 Enforce uniform trailing slash handling
💅 Refactors
  • cli
    • #​6353 Call setup hook in run command with more args
  • builder
    • #​6352 Await build.createRoutes to allow async functions inside it
  • babel-preset-app
📝 Examples
  • with-sockets
    • #​6396 Create server inside the export function
🏡 Chore
  • general
    • Fix example in babel-preset-app readme
    • #​6390 Lint vue-app templates
    • #​6363 Rename setup hook to run:before
💖 Thanks to

v2.9.2

Compare Source

🐛 Bug Fixes
  • general
    • #​6257 Improve watching experience for generated files
  • builder
    • #​6283 fix(builder): apply overrides from app dir only
  • server
    • #​6265 Treat https: null as https: undefined
  • nuxt-start
    • #​6267 Add missing vue-client-only dependency
  • vue-app
    • #​6264 Only overwrite leave listener when none provided or without done arg
    • #​6255 Enforce default css when used with frameworks
  • config
    • #​6258 Provide typescript backward compatibility
💅 Refactors

v2.9.1

Compare Source

🐛 Bug Fixes
📝 Examples
  • CoffeeScript
    • #​6248 Update module for using additionalExtensions
💖 Thanks to

v2.9.0

Compare Source

️ Important Notes
  • 👉 Minimum required node version is 8.9.0
  • 👉 Typescript support is now externalized. Refer to official docs and migration guide.
  • 👉 vue-meta upgraded to 2.0.0. Please refer to the changelog to review notable changes.
  • 👉 scrollBehavior option is deprecated in favor of app/router.scrollBehavior.js (#​6055)
  • 👉 devModules option is deprecated in favor of buildModules (#​6203)
🐛 Bug Fixes
  • general
    • #​6118 Fix modulepreload warnings
    • #​6075 Throw error when building failed in quiet mode
    • #​6070 Support babel corejs config for modern mode
    • #​6021 Babel polyfill can not be disabled
  • renderer
    • #​6033 Correctly load nomodule scripts in safari 10
  • cli
    • #​6020 Prevent both nuxt & nuxt-edge being installed
  • vue-app
    • #​6012 Emit triggerScroll to support hash navigation
    • #​5920 Fix font-size and make width bigger
    • #​5891 Always finish transition.leave asynchronously
    • #​5890 Fix position of the build indicator when page scrolled
  • vue-renderer
    • #​6223 Call render:resourcesLoaded hook before createRenderer
    • #​5964 Clone SPA meta to prevent cache modification
  • webpack
    • #​5906 Extract css breaks hmr and source-maps
🚀 Features
  • cli
  • server
    • #​6178 Allow passing loadingTimeout and other arguments to renderAndGetWindow
  • webpack
    • #​6120 Allow function entries for build.transpile
  • vue-app
    • #​6194 Add $nuxt.refresh
    • #​6186 Use EventSource instead of WebSocket for build indicator
    • #​6055 Support app/router.scrollBehavior.js and deprecate scrollBehavior
    • #​5941 Add <client-only> alias for <no-ssr>
    • #​5844 Allow customizing loading indicator
    • #​6194 Add $nuxt.refresh() method or refresh the actual page asyncData and fetch
    • #​6231 Export router options
    • #​6222 Support functional watchQuery
  • vue-renderer
    • #​5975 Add csp option for csp v1 compatibility
    • #​6134 Support prepend/append body tags during ssr for all allowed tag types
  • typescript
    • #​5858 Externalize typescript support
💅 Refactors
🏡 Chore
Dependency Upgrades
  • file-loader@4
  • url-loader@2
  • cache-loader@4
  • css-loader@3
  • vue-meta@2
  • fs-extra@8
💖 Thanks to

v2.8.1

Compare Source

🐛 Bug Fixes
  • vue-renderer
    • #​5867 Fix exception on property access of undefined object
    • #​5863 Prevent "can't set headers after they are sent" error in modern server mode
  • vue-app
    • #​5864 Reduce consola direct access and don't override browser console.log
  • cli
    • #​5865 Don't mutate options export to prevent ESM regression with nuxt.config in mixed (cjs + esm) mode (TIP: never mix them as is non-standard and may be unsupported in any future version)
💅 Refactors
  • typescript
    • #​5854 Prepare for external typescript support
💖 Thanks to

v2.8.0

Compare Source

😎 Developer Experience
  • #​5770 Add a group for SSR logs to avoid polluting the browser console
  • #​5810 Fancier browser logs with consola

nuxt-ssr-logs-2

nuxt-hmr-indicator

  • #​5753 Watch for pages/ creation when default page displayed
  • #​5812 Only listen for file changes for supported extensions
  • #​5753 Re-use the same port when randomly assigned when restarting in dev mode
🐛 Bug Fixes
  • vue-renderer
    • #​5807 Add User-Agent‍ to Vary header in modern server mode
    • #​5764 Safe format SSR logs
  • server
    • #​5793 Preserve random port when restarting
    • Return listener when calling listen
  • builder
    • #​5753 Watch for pages/ creation when default page displayed
    • #​2812 Only listen for file changes for supported extensions
  • generator
  • types
    • #​5785 Add type definition for functional babel.presets
  • vue-app
    • #​5757 Reuse page component with watchQuery
    • #​5746 Remove trailing slash in vue-router non-strict mode
    • #​5752 Don't attach catch handler to already loaded component
    • #​5824 fixPrepatch in-out transition fix (issue #​5797)
  • utils
    • #​5754 Handle serializeFunction edge case
🚀 Features
  • vue-renderer
    • #​5745 Add render.injectScripts option
    • #​5784 Support render.ssrLog for controlling SSR logs
💅 Refactors
  • core
    • #​5796 Use require.resolve instead of Module internals
  • builder
    • #​5792 Pass nuxt options to template as nuxtOptions
  • vue-app
  • general
    • #​5748 Small readability improvements
📝 Examples
  • auth-jwt
    • #​5775 Use named store export to prevent warning
  • typescript
    • #​5742 Add missing ts-node dependency
🏡 Chore
  • ci
    • #​5802 Upload test report to CircleCI and Azure
    • Add flags for codecov
    • Enable audit
  • general
    • Remove unused dependency cross-env
    • Add FUNDING.md
    • Improve links in readme
️ Tests
  • general
    • #​5790 Add unit tests for core/resolver.js
    • #​5782 Remove duplicate unit tests in packages/core/test/resolver
Dependency upgrades
💖 Thanks to

v2.7.1

Compare Source

Fixes

  • builder: use warn only for mismatched dependencies (#​5723)
  • webpack: correctly resolve consola for the client bundle (#​5729)

Dependency Upgrades

Thanks to

v2.7.0

Compare Source

DX Improvements 💅

SSR logs in your browser 🖥

We all know the console.log debugging method, but when working with universal applications, you have to remember that sometimes, your logs are in your terminal and not in your browser console.

This can be really annoying when developing a Nuxt.js application, starting with this version and running nuxt dev, the ssr logs are now reported to your browser console:

nuxt-logs-ssr

Detecting store/ creation 👀

Nuxt.js now detects when you created a store/ directory and will reload himself auto-magically so you don't have to restart it anymore.

nuxt-store-watch

PS: We also improved the serverMiddleware watch to restart Nuxt.js and clean their cache

Fixes

  • builder: corretly detect mode of hashed plugins (#​5695)
  • builder: call watch:restart after watch:fileChanged hook (#​5620)
  • utils: node v8 not support dotAll in regex (#​5608)
  • vue-app: properly catch component loading error (#​5687) (#​5688) (#​5690)
  • vue-app: consider watchQuery option in routerViewKey (#​5516)
  • vue-renderer: await on spa:templateParams hook (#​5619)
  • webpack: set log level to warn for HardSourcePlugin (#​5653)
  • vue-app: properly catch loading error in component prefetching (#​5688) (#​5690)
  • vue-app: avoid using aliases in templates (#​5656)
  • builder: watch store dir and serverMiddleware paths (#​5681)

Features 🚀

  • vue-app: rename transition to pageTransition and deprecate it (#​5558)
  • vue-renderer/vue-app: report SSR console logs to the browser with consola (#​5673)
  • webpack: suppress not found typescript warnings (#​5635)
  • webpack: extendable babel.presets and babel envName (#​5637)
  • configurable aliases (#​5655)

Refactors 🧹

  • server: exclude dist files request from browser detection (#​5571)
  • vue-renderer: remove chalk in renderer (#​5609)
  • vue-renderer: split renderer into ssr, spa and modern (#​5559)
  • move modern detection from server to utils (#​5584)

Examples 📚

  • auth-routes: fix typo (#​5651)
  • babel-preset-app: add core-js@3 example in the readme (#​5633)
  • docker: fix Dockerfile casing (#​5705)

Typescript 👷

Only for typescript users, Nuxt.js v2.7 dropped support for node < 8.6 relate to ts-loader v6

Thanks to 🙏

v2.6.3

Compare Source

Fixes

  • cli: Watch and reload nuxt.config (#​5574)
  • utils: serialize inline functions (#​5051) (#​5580)
  • vue-app: Fix context req and res types (#​5560)
  • webpack: Fix production font preloading (#​5436)
  • Don't customize esm options (91c3642)

Dependency Upgrades

  • Update webpackbar to ^3.2.0
  • Update vue-router to ^3.0.6
  • Update @nuxt/loading-screen to ^0.5.0

v2.6.2

Compare Source

Fixes

  • cli: Apply nuxt.config.js changes and watch for all imported files (#​5500)
  • cli: Fix problem for users that have tsconfig.json but do not use typescript (#​5478)
  • cli: Show memory usage after build for nuxt dev (#​5514)
  • server Fix bug with SPA mode with CSP enabled (#​5474)
  • vue-renderer: Use modulepreload for modern mode when using spa generate (#​5489)
  • webpack: Suggest using official @nuxtjs/style-resources package (#​5499)
  • Custom router.base support for banner url and loading screen (#​5470) (nuxt/loading-screen#​8)

Security Fixes

Thanks to our awesome contributors to this release

v2.6.1

Compare Source

v2.6.0

Compare Source

Migration Guide

This version is addressing most of the problems of 2.5 and is without any breaking changes. For most of the users, a normal version upgrade would be enough. However, reading this guide can help to have a smooth upgrade.

General Tips

  • Using yarn as the package manager is more preferred as Nuxt is internally being tested against yarn
  • Before upgrade ensure to remove yarn.lock, package-lock.json and node_modules
  • After full install and testing, also consider upgrading other dependencies. The yarn outdated command can be used.
Missing App Dependencies

Because of how package managers (yarn, npm) work, a wrong version of a dependency from one of the other dependencies may be hoisted into node_modules. Nuxt is strict about this and provides instructions for dependency resolution so please follow it.

The well-known problem is with firebase package that requires to manually install node-fetch dependency in your project.

Reverting breaking changes

We accidentially introduced a change that broke the prod build for many people who are using Nuxt programatically. This has been resolved through #​5413. Sorry for the inconveniences!

Core-js

Since core-js@2 and core-js@3 are both supported from babel 7.4.0, Starting from 2.6 Nuxt supports both versions (#​5411). It is highly advised to stick with 2 (default) unless having a special dependency that needs 3. (Instructions for core-js@2 are not required but recommended)

core-js@2
  • yarn: yarn add -D core-js@2 @&#8203;babel/runtime-corejs2
  • npm: npm i -D core-js@2 @&#8203;babel/runtime-corejs2
core-js@3
  • yarn: yarn add -D core-js@3 @&#8203;babel/runtime-corejs3
  • npm: npm i -D core-js@3 @&#8203;babel/runtime-corejs3

Edit nuxt.config.js:

export default {
  build: {
    babel: {
      presets({ isServer }) {
        return [
          [
            require.resolve('@&#8203;nuxt/babel-preset-app'),
            // require.resolve('@&#8203;nuxt/babel-preset-app-edge'), // For nuxt-edge users
            {
              buildTarget: isServer ? 'server' : 'client',
              corejs: { version: 3 }
            }
          ]
        ]
      }
    }
  }
}
Typescript

Nuxt 2.5 users may only require to add ts-node to the dependencies

Beta Testers : Replace nuxt by nuxt-edge, and @nuxt/typescript by @nuxt/typescript-edge in the following instructions.

  1. Remove nuxt-ts dependency (2.4 users only)
    • yarn: yarn remove nuxt-ts
    • npm: npm remove nuxt-ts
  2. Add nuxt and ts-node to dependencies:
    • yarn: yarn add nuxt ts-node
    • npm: npm i nuxt ts-node
  3. Add @nuxt/typescript to devDependencies:
    • yarn: yarn add -D @&#8203;nuxt/typescript
    • npm: npm i -D @&#8203;nuxt/typescript
  4. Create an empty tsconfig.json file. Nuxt will automatically generate it with defaults at first run, then you can edit it to fit your needs

Features

  • feat(babel-preset-app): support specifying core-js version (#​5411) (Xin Du (Clark)) (159123f)
  • feat(cli): add internal _generate and _build options (#​5434) (Pooya Parsa) (516aea3)
  • feat(cli): add --quiet option to nuxt generate command (#​5357) (Franck Abgrall) (91f4eb0)
  • feat(typescript): detect typescript based on tsconfig.json (#​5412) (Pooya Parsa) (6ffc5c5)
  • feat(vue-renderer): add csp meta tags (#​5354) (James George) (b978a37)

Fixes

  • fix: unexpected token export in importing babel runtime helper (#​5401) (ryota yamamoto) (3b85dd9)
  • fix(core): call ready to prevent breaking changes (Pooya Parsa) (#​5413) (001ba77)
  • fix(build): disable loading babel.config.js by default (#​5365) (Xin Du (Clark)) (64fa424)
  • fix(builder): await for renderer to load resources (#​5341) (Pooya Parsa) (caf5198)
  • fix(cli): catch all possible errors thrown from proper-filelock (#​5347) (Pim) (39bbe46)
  • fix(renderer): retry render if renderer is in loading or created state (#​5417) (Pooya Parsa) (8b99695)
  • fix(vue-app): decode uri in getlocation (#​5337) (Johan Roxendal) (77dcfe6)
  • fix(vue-app): prevent mounting page twice on redirect (#​5361) (noe132) (2d73e8a)
  • fix(vue-renderer): add the csp hash if unsafe-inline hasn't been specified (#​5387) (Sam Bowler) (97db6a4)
  • fix(types): add type definition for typescript.typeCheck (#​5326) (Daniel Roe) (2c1444d)

Refactors

  • refactor(typescript): only generate tsconfig.json if missing (#​5356) (#​5367) (Kevin Marrec) (9a3fc8a)
  • refactor(vue-renderer): improve ready status error (#​5339) (Pooya Parsa) (535327c)
  • refactor(webpack): add ability to get webpack config class (#​5378) (Damian Stasik) (abf7db1)

Examples

Chore

Dependency Upgrades

v2.5.1

Compare Source

Bug Fixes

  • fix: revert to corejs@2 (#​5317) (Pooya Parsa) (20836d9)
  • fix: remove consola.debug for hooks (#​5318) (Thomas Reichling) (9ff01f9)
  • fix: apply default lock options before setting lock (#​5320) (Pim) (7c24280)
  • fix(ts): wrong export used in render.d.ts (#​5309) (Romain Lanz) (e67b298)
  • examples: upgrade and fix typescript configuration files (#​5310) (Romain Lanz) (7100a2c)
  • chore: unsupport nuxt-legacy (pooya parsa) (797a4ce)

v2.5.0

Compare Source

15,000 line changes with 230 squashed commits by more than 30 contributors made this version possible!

What's new?

Typescript DX

No longer needed to install nuxt-ts for typescript support. Nuxt.js officially supports TS by installing @nuxt/typescript. Please see #​5079 for reasons behind such migration.

Babel

Babel 7.4, Core-js v3, and Object.assign polyfill for better browser support.

Stability

More than 30 fixes, refactors and performance improvements.

Open in Browser

Use nuxt dev -o to instantly open project in the browser and enjoy a cool loading screen:

nuxt-loading-screen

.nuxtignore

Before v2.5, you were able to ignore files through an ignore prefix. As using the prefix over and over, ignoring files (and implementing custom structures) was a bit tedious on the long run. We came up with something more sophisticated: A .nuxtignore file. Following the same specs as a .eslintignore or a .gitignore file, you can now define what files or folders to ignore through a .nuxtignore file in your project root.

Examples and more info in the .nuxtignore docs

[IMPORTANT] Migration Guide

Lock Files

For a clean upgrade, please remove yarn.lock / package-lock.json file from your project before upgrade.

Programmatic API / Middleware

If not already done, please explicitly call nuxt.ready() after new Nuxt(). nuxt.ready() was always async, but not awaiting the function call has now a severe impact.

   const nuxt = new Nuxt(config)
++ await nuxt.ready()
TypeScript
  1. Please replace nuxt-ts dependency and use nuxt + @nuxt/typescript. (Also nuxt-ts-edge to nuxt-edge + @nuxt/typescript-edge for edge users)
{
--  "nuxt-ts": "^2.4.2"
++  "@&#8203;nuxt/typescript": "^2.5.0"
++  "nuxt": "^2.5.0"
}
  1. Configuration API to customize/disable type checking has been moved from build.useForkTsChecker to build.typescript.typeCheck. Please see #​5079 for more details.
build: {
-- useForkTsChecker: false // or ForkTsChecker options
++ typescript : {
++   typeCheck: false // or ForkTsChecker options
++ }
}

Features

  • feat(babel): include es6.object.assign by default (Clark Du) (52fe145)
  • feat(cli): lock project during build or generate (#​4985) (Pim) (4e51723)
  • feat(cli): option to open the project in the browser (#​4930) (Ricardo Gobbo de Souza) (4c7bd9c)
  • feat(generate): return non-zero code or page error (fixes #​4991) (#​5195) (Jarek Lipski) (c6565c9)
  • feat(module): support src as a function in addModule (#​4956) (Ricardo Gobbo de Souza) (1e9eb4b)
  • feat: support .nuxtignore (#​4647) (Xin Du (Clark)) (59be77a)
  • feat: support devModules option (#​5102) (Jonas Galvez) (e87711c)
  • feat(ts): nuxt configuration typedefs (#​4854) (Kevin Marrec) (92f81e0)
  • feat(vue-app): universal fetch (#​5028) (Pooya Parsa) (2015140)
  • feat(vue-renderer): improvements (#​4722) (Pooya Parsa) (2929716)
  • feat(vue-renderer): use async fs (#​5186) (Pooya Parsa) (d07aefa)
  • feat(ts): better DX for typescript support (#​5079) (Kevin Marrec) (920f444)
  • feat: loading screen (#​5251) (Sébastien Chopin, Pooya Parsa) (ef41e20)
  • feat: support core-js 3 (#​5291) (Xin Du (Clark)) (d094c4a)

Fixes

  • fix(builder, vue-app): order of plugin execution based on order in array (#​5163) (Dmitry Molotkov) (a867dbd)
  • fix: correct public path in generation and start (#​5202) (Xin Du (Clark)) (648062c)
  • fix: default for-exit to false to prevent dev exit (pooya parsa) (a347ef9)
  • fix: disable "analyze" for nuxt generate (#​4975) (Alexander Lichter) (574a2eb)
  • fix: disable parallel build when extractCSS is enabled (Clark Du) (aad46ed)
  • fix: extra properties in templateFiles (#​4925) (Xin Du (Clark)) (ca19124)
  • fix: fix non standard esm modifications (pooya parsa) (fb87a55)
  • fix: generate failure (#​5007) (Andrey Shertsinger) (bcd672f)
  • fix: keep-alive component data should not be updated (#​5188) (Xin Du (Clark)) (1ea8661)
  • fix: not send Server-Timing header if no timing info (Clark Du) (d9a0b5f)
  • fix(postcss): default to preset-env and cssnano last (#​5215) (Alexander Lichter) (adf423a)
  • fix: publicPath is not reactive in dev restarting (#​5227) (Xin Du (Clark)) (1fb7538)
  • fix: refactor file watchers (chokidar/linux workaround) (#​4950) (Pim) (5ec5932)
  • fix: remove cache-loader for external resources (#​4915) (Xin Du (Clark)) (0223e56)
  • fix: respect namespaced in store module (#​5189) (Xin Du (Clark)) (9e1ef88)
  • fix: revert templatFiles name (#​4924) (Xin Du (Clark)) (f70645e)
  • fix: trailing comma in tsconfig (#​5061) (Sergey Vikulov) (1fb44d9)
  • fix(ts): deprecate isClient, isServer, isStatic (#​5211) (Daniel Hritzkiv) (29c3c42)
  • fix(types): reflect chainlable NuxtLoading methods (#​5104) (Matjaž Lipuš) (66273f4)
  • fix: Unexpected token .... Expected a property name in Safari (Clark Du) (eef7f69)
  • fix(vua-app): clone mount error to prevent mutating read-only error object (#​5214) (Alexander Lichter) (37006f6)
  • fix(vue-app): avoid css chunk error (#​5173) (Yutaka Sasaki) (41028a4)
  • fix(webpack): clone config.entry (fixes #​4849) (#​5236) (Julien Dargelos) (8216765)
  • fix: disable extract-css-chunks-webpack-plugin in dev mode (#​4888) (Xin Du (Clark)) (928a230)
  • fix(server): handle decodeURI error (#​5243) (phof) (5b7f6d7)
  • fix: correct socket address in use error message (Clark Du) (2eb1965)
  • fix(utils): relax lock settings (#​5280) (Pim) (65a431d)
  • fix(vue-app): multiple named views cause invalid syntax (#​5262) (Michael Leaney) (d03a61b)
  • fix(webpack): loaders in extend config is broken (#​5292) (Xin Du (Clark)) (0eb5ed9)
  • fix(vue-app): duplicated router.base when using context.redirect(object) (#​5290) (Nianyong) (cf02e82)
  • fix(vue-app): decode router base to support unicode characters (#​5297) (Alexander Lichter) (3ac01df)

Performance Improvements

  • perf: await routeData promises in parallel (#​5027) (Alexander Lichter) (0826d7e)
  • perf(core): skip esm for node_modules and non .js files (#​5220) (Pooya Parsa) (aabb1f6)
  • perf(webpack): use futureEmitAssets (#​5003) (Alexander Lichter) (3997d50)
  • perf(ts): transpileOnly when using nuxt-ts start (#​4906) (Kevin Marrec) (17cc12f)

Examples

  • examples(jest-puppeteer): fix package .json (#​4997) (Andrew Cravenho) (dfc8dd5)
  • examples: improve vuex store example (#​5017) (Alexander Lichter) (a9511e5)
  • examples(pug): fix example by adding plain-pug-loader (#​5223) (Paul Geisler) (320a46f)
  • examples(vuex-store): change to module store (#​4923) (Alexander Lichter) (be41ae1)
  • examples: add pug-stylus-coffee (#​4927) (chiboreache) (6d05969)
  • examples: add tsx example (#​4855) (andoshin11) (5101dc6)
  • examples: fix jest test dependencies (#​5155) (Dmitry Molotkov) (1c3761a)
  • examples: fix links to vue-meta repo (#​5018) (Pim) (06f4762)
  • examples: rebase on latest stable nuxt version (#​4874) (Alexander Lichter) (47898fb)
  • examples: zero-downtime pm2 typescript example (#​4907) (Dmytro) (1fb9af3)
  • examples: fix dynamic components example (#​5294) (Dmitry Molotkov) (d9db45c)

Refactors

  • refactor: generate routes and template files in builder (#​4883) (Xin Du (Clark)) (4c5a59e)
  • refactor: improve modern middleware and spa modern rendering (#​5037) (Xin Du (Clark)) (05299d6)
  • refactor: isModernBrowser return boolean for avoiding duplicate call (Clark Du) (c6d8e8f)
  • refactor: not detect modern browser if modern mode is disabled (Clark Du) (2b4d79c)
  • refactor: remove builder coupling from server (#​5157) (Pooya Parsa) (13cb0f7)
  • refactor: remove unnecessary onEmit in old webpack (Clark Du) (eac6d02)
  • refactor: some small stuff (#​4979) (Alexander Lichter) (69dfd84)
  • refactor: fix typos (#​4922) (Alexander Lichter) (569b6aa)
  • refactor: unify context in webpack module (#​5054) (Xin Du (Clark)) (9860eb6)
  • refactor: use spread syntax for plugin push (#​4976) (Alexander Lichter) (31cb187)
  • refactor: fallback to babel-preset-env defualt targets when buildTarget is not specified (Clark Du) (176641f)
  • refactor(ts): add warning for nuxt-ts deprecation (#​5301) (Kevin Marrec) (a11afd4)

Chore

  • chore(babel-preset): create readme with basic docs (#​5127) (HG) (04cdd60)
  • chore: don`t ignore .nuxtignore (#​5169) (Dmitry Molotkov) (39c9ab5)
  • chore: enable yarn.lock maintenance (#​5063) (Xin Du (Clark)) (17b53eb)
  • chore(vue-app): suppress deprecated warning for classic vuex in prod (#​5137) (Shingo Sato) (f39205a)

Tests

  • test: add await for promisable expect (Clark Du) (fabf1c0)
  • test: add chrome detector (#​4984) (Xin Du (Clark)) (855705b)
  • test: add describe.posix and win (Clark Du) (e9ba2f9)
  • test: fix macos e2e tests (Pooya Parsa) (2c763df)
  • test: improve nuxt-loading component tests (#​5005) (Pim) (75a7454)
  • test: mock enquirer in typescript tests (#​5025) (Pim) (ad6a8cd)
  • test: skip reqest in dev test for now (Clark Du) (3e67879)
  • test: try to fix unhandled request (Clark Du) (2f2baac)
  • test: turn off cli dev test (Clark Du) (5c053f5)
  • test: unit tests for generator (#​4857) (Xin Du (Clark)) (e22a282)
  • test: unit tests for @​nuxt/util (#​4880) (Xin Du (Clark)) (96bab9f)
  • test: unit tests for server module (#​5154) (Xin Du (Clark)) (cc573a4)
  • test: update cli snapshot (Clark Du) (3dd1a28)
  • test: unhandled open handles (Clark Du) (858c9ee)
  • test: change cli.test to be more accurate (#​4957) (Xin Du (Clark)) (68f6880)
  • test: use puppeteer-core (#​4929) (Pooya Parsa) (940a36f)
  • test: fix e2e test by downloading chromium (#​5254) (Pooya Parsa) (2561b68)
  • test: fail tests in case of unhandled errors (#​5255) (Pooya Parsa) (d6b505a)

v2.4.5

Compare Source

v2.4.5 (2019-02-26)

Bug fixes and Improvements

v2.4.3

Compare Source

🐛 Bugfixes

  • webpack: Update dependency terser-webpack-plugin to ^1.2.2.
  • webpack: Update dependency webpack to ^4.29.2
  • utils: Fix serializeFunction for external imports (#​4916)
  • config: Warn when using array for postcss config (#​4936)
  • module: support src as a function in addModule (#​4956)
  • server: await buildDone hook (#​4955)

v2.4.2

Bugfixes

  • Handle async components correctly when using nuxt-ts (MR #​4886)
  • Fix extractCSS in dev mode (MR #​4892)
  • Correctly apply class when using linkPrefetchedClass (MR #​4893)

v2.4.0

Compare Source

Upgrade Note

Due to a known problem (webpack/webpack#​8656, #​4869, #​4839) users of npm should either remove package-lock.json and reinstall before upgrade or use npm update acorn --depth 20 && npm dedupe after upgrading to 2.4.0. yarn users should have no problems but removing yarn.lock still recommended before the upgrade process.

Important news 👀

New core team member 🐤

We are really proud to announce Kevin Marrec (@​kevinmarrec) as a new core team member of Nuxt.js. He is French 🇫🇷 and responsible for the TypeScript integration 💚

Official Consulting

We now offer official support & consulting from the core team. We partnered with Otechie for the process and already did some beta-tests with selected companies.

Are you interested or curious? Learn more on https://otechie.com/nuxt 🙌

RFC Process 📎

We invite you to take a look at our nuxt/rfcs repository where we discuss the future of Nuxt and its vision.

Here are some interesting proposals if you want to learn more about the upcoming changes of Nuxt:

Release Plan 🚢

Starting with this release, Nuxt will adhere to a formalized release plan (as good as possible). Also, an end of life for older major versions is defined within RELEASE_PLAN.md.

Quick summary:

  • Nuxt major releases are planned every 6 months.
  • The release cycle for Nuxt.js minor versions is roughly 4 weeks.
  • Fixes will be released as soon as possible after the actual MR/commit

We strongly invite you to read the RELEASE_PLAN.md for further details.

Thank you

We want to specially thanks:

  • Our contributors submitting bug reports, feature requests and commenting on issues
  • Our users participating on our Discord server and sharing the love by mentioning our Twitter account
  • All the devs working for companies using Nuxt.js and who helped us building a showcases list
  • Our backers and sponsors supporting us financially through our open Collective

New Features

Speaking of TypeScript...

TypeScript support has landed!

nuxt-ts

In order to run Nuxt with TypeScript, we created a new distribution, called nuxt-ts (we also have nuxt-ts-edge). We want to thank @​hmsk for his donation of the package name on npm

You can explore Nuxt TypeScript example or play with it directly in our Nuxt TS CodeSandBox.

For a more advanced example, you can look at the HackerNews-TS repo or play with it on CodeSandBox, made by @​husayt & @​kevinmarrec.

This work has been made by @​kevinmarrec with the help of @​pi0 & @​Atinux.

Experimental: We are waiting for your feedback to keep improving it and breaking changes can occur without a semver major release. However, all changes will be documented properly

Smart prefetching

Nuxt.js will automagically prefetch the code-splitted pages linked with <nuxt-link> when visible in the viewport by default. This hugely improves the end user performances, inspired by quicklink.

nuxt-prefetch-comparison

Demos are online and we recommend you to try it out to feel the difference:

Bonus: we added $nuxt.isOnline and $nuxt.isOffline which is reactive, so you can use it directly inside your components (see this example).

You can learn more about this feature in the associated MR #​4574 and in the documentation.

HMR & best practices for store/ 👀

Save more development time with full HMR support for the store (mutations, getters, and actions).

nuxt-vuex-hmr

This feature has been implemented by @​manniL & @​Atinux on MRs #​4589, #​4582 and #​4791

Autocomplete for VS Code (via. Vetur extension)

If you are using VS Code, with this version, you will now have autocomplete for Nuxt.js components:

nuxt-vs-autocomplete

This feature has been implemented by @​octref & @​Atinux on MR #​4524

Port taken? Nuxt got your back! 💪

If Nuxt wants to listen on a port which is already used, it will warn you in development and listen to a free port instead:

49249621-efe2e780-f431-11e8-90fb-ba48e67ba5c9

In production it will throw an error instead to avoid unwanted behavior:

49249634-f8d3b900-f431-11e8-9f51-afbf3ffc68ed

This feature has been implemented by @​ricardogobbosouza on MR #​4428 with the help of @​pi0 and @​manniL.

Suggest installing missing dependencies or mismatches 💯

Nuxt requires all peer like dependencies as a dependency for easier usage. Sometimes this causes unwanted behaviors when users explicitly add a specific version in their package.json which is incompatible with nuxt. This could also help to resolve popular Vue packages version mismatch error (#​198, #​669, #​1084, #​1414, #​1851, #​2079, #​2406, #​3454).

Nuxt is now able to automatically self-verify installed dependencies and warn with a proper message in case of detecting problems.

image

This feature has been implemented by @​pi0 in MR #​4669

Auto-detection of modern bundles 🥇

When running nuxt start, Nuxt will automatically detect if you built your app modern mode enabled. No need to run nuxt start --modernexplicitly anymore 🌟

screenshot 2018-11-30 at 16 55 48

This detection was created by @​clarkdo on MR #​4422

Plugin modes and file extensions 💅

Until now, you used ssr: false in your plugin declarations to disable server-side rendering. We decided to deprecate that option and introduce a mode instead, which can be 'all', 'client' or 'server'. No worries, ssr is still working (until Nuxt 3).

The new feature coming with the mode is that you can define it by using the file suffix:

  • plugins/plugin.server.js
  • plugins/plugin.client.js
  • plugins/plugin.js

By adding the plugins to your nuxt.config.js:

plugins: [
  '~/plugins/plugin.server.js',
  '~/plugins/plugin.client.js',
  '~/plugins/plugin.js'
]

The declaration will be internally transformed to:

plugins: [
  { mode: 'server', src: '~/plugins/plugin.server.js' },
  { mode: 'client', src: '~/plugins/plugin.client.js' },
  { mode: 'all', src: '~/plugins/plugin.js' }
]

(If you specify the mode manually, it will overwrite the suffix detection)

This feature has been implemented by @​clarkdo on MR #​4592

Module commands 🖥

Nuxt modules can now include bin scripts that are recognized by Nuxt's CLI.

Here's an example of my-module/bin/command.js:


#!/usr/bin/env node

const consola = require('consola')
const { NuxtCommand } = require('@&#8203;nuxt/cli')

NuxtCommand.run({
  name: 'command',
  description: 'My Module Command',
  usage: 'command <foobar>',
  options: {
    foobar: {
      alias: 'fb',
      type: 'string',
      description: 'Simple test string'
    }
  },
  run(cmd) {
    consola.info(cmd.argv)
  }
})

The command could be run with:

npx nuxt command arg1 arg2

You can learn more about that in the modules command documentation.

Experimental: We are waiting for your feedback to keep improving it and breaking changes can occur without a semver major release. However, all changes will be documented properly <3

This feature has been implemented by @​galvez on MR #​4314 with the help of @​pi0.

PostCSS in Vue Components 💃

You can now use lang="postcss" in your Vue components. Postcss has applied to all your styles anyway (e.g. to resolve aliases like ~) but the lang attribute enables autocomplete and syntax highlighting for some IDEs.

nuxt-postcss

This feature has been implemented by @​manniL on MR #​4417.

No more extensions for Stylesheets needed 🦅

stylesheet extensions

We are concerned to improve the Developer Experience ("DX") with each release. This small change allows you to omit the file extension for CSS/SCSS/Postcss/Less/Stylus/... files listed in the css array inside your nuxt.config.js. For the plugins or serverMiddleware key, this is already possible.

This feature has been implemented by @​manniL on MR #​4671.

SSR Bundle improvements 🔹

We made a full rewrite of how SSR bundle is packaged.

This means better performance, less memory overhead, fewer OOM crashes and easier SSR bundle debugging.

_ | Before | After | Diff -------|-----------------------|-----------------------|------------------------- Dist | 8.2M | 7.2M | -1M / 12% Dev | 281 MB (RSS: 439 MB) | 237 MB (RSS: 354 MB) | -44M / 16% (RSS: -85M / 19%) Start | 106 MB (RSS: 169 MB) | 71.7 MB (RSS: 137 MB) | -34M / 32% (RSS: -32M / 19%)

This feature has been implemented by @​pi0 on MR #​4439.

Other changes 🌔

  • process.modern can be used for distinguishing modern environment.
  • Add server.timing to give Server-Timing header, useful for monitoring and performances overview (MR #​4800)
  • ️ Experimental: Enable HardSourceWebpackPlugin by hardSource: true in hardSource of nuxt.config.js
  • You can now set scrollToTop to false in pages (MR #​4564)
  • Aliases for nuxt-link and nuxt-child (n-link and n-child) are available now (MR #​4525)
  • Components can now be used in PascalCase as recommended by the Vue styleguide (MR #​4396)
  • VueMetas headAttrs are now supported for the appTemplate (MR #​4536)
  • More browsers are added to the list of modern browsers (MR #​4516, MR #​4775)
  • Loaded resources can now have a crossorigin attribute (MR #​4472)
  • Modern mode resources are preloaded and will be pushed via HTTP2 server push if set (MR #​4508)
  • Add option to disable the compression middleware (MR #​4381)
  • Add option to disable the FriendlyErrorsWebpackPlugin overlay (MR #​4381)
  • Add exclude option to exclude pages from being generated (in static mode) but still get rendered via fallback/SPA (MR #​4754)
  • Support build.hotMiddleware.client (MR #​4796)
  • New examples have been added:
  • Internal changes:
    • feat: use runInNewContext: true for nuxt dev (#​4508)
    • feat: check modern build file in modern mode (#​4467)
    • refactor: migrate to extract-css-chunks-webpack-plugin (#​4495)

Further Patches (30+) 🔍

v2.3.4

Compare Source

(Please skip v2.3.3 release. It was mistaken.)

🔧 Fixes

  • CLI: nuxt-start command should always start nuxt in production mode (#​4384)
  • Modern Mode: Fix behavior where modern=true or false didn't work as expected (#​4378)
  • Router: Correctly handle Unicode page names (#​4402)
  • Router: Emit triggerScroll event after changing the layout (#​4399)
  • Components: Allow 0 values for progress bar attributes (#​4397)
  • Server/Tests: Correctly print timeout error message for JSDom (#​4412)

️ Dependencies

  • Update dependency vue-router from 3.0.1 to 3.0.2 (#​4394)
  • Update dependency @nuxt/friendly-errors-webpack-plugin from 2.3.0 to 2.3.2
  • Update dependency mini-css-extract-plugin from 0.4.4 to 0.4.5
  • Update dependency webpack from 4.26.0 to 4.26.1
  • Update dependency vue-meta from v1.5.5 to v1.5.6
  • Remove opencollective dependency from nuxt-start (#​4415)
  • Remove lodash dependency from packages to reduce the nuxt-start size (#​4411)

v2.3.3

Compare Source

v2.3.2

Compare Source

Fixes

  • Use exact versions for Nuxt internal packages
  • Fallback to default value when publicPath is falsy (#​4365)
  • Add lodash inside templating (#​4368)

v2.3.1

Compare Source

📝 Release Notes

With v2.3, Nuxt.js is splitted into smaller packages (Aka a mono-repo). This means smaller packages, independent versioning support and ability to replace any part of Nuxt.js without dirty hacks. Before this release, we carefully tested the latest updates using edge release channel against real-world projects and there should be no breaking changes.

Please note that for upgrading Nuxt.js just changing version inside package.json is not enough. Please use yarn upgrade or npm upgrade so that the final directory structure of node_modules will be correct. In case of problems clean up node_modules and yarn.lock/package-lock.json. Still having problems? open an issue in cmty!

🔧 Fixes and Enhancements

  • CLI and DX improvements (#​4259)
  • CLI cleanups and improvements (#​4222)
  • Improve nuxt-loading component (#​3891)
  • Set defaults for port and host values (#​4207)
  • Dynamically read environment variables when loading nuxt.config.js (MR #​4208)
  • Support custom pushAssets function to control http2 push headers (#​4198)
  • Reduce duplicate code in routes.js (#​4121)
  • Print warning when using build.extractCSS.allChunks (#​4097)
  • Throw an error when layout property is not string (#​4142)
  • Use require.resolve to get the path of babel-loader (#​4150)
  • Check style resources for existence (#​4155)
  • Serialize config head fn shorthand correctly (#​4283)
  • Don't accept ranges (#​3870) (#​4295)
  • Correctly resolve layouts with nested custom dir (#​4135)
  • Warn on unknown mode (#​4303)
  • Use postcss.order to change order of postcss plugins(#​4318)
  • Fix for double escaping static class on SSR (#​4312)
  • Fix stable route sorting for Node v11 (#​4331)

🎉 New Features

️ Dependency Upgrades

️ Deprecations

  • Deprecate styleResources because of performance issues. Use our new community module instead (it's a drop-in replacement) (#​4302)
  • Deprecate callback-based asyncData, fetch and middleware methods. Use Promises or async/wait instead. (#​4256)

💄 Internal Refactors

  • Migrate nuxt into a mono-repo (#​4051)
  • Refactor core into @nuxt/core, @nuxt/server and @nuxt/vue-renderer (#​4202)
  • Refactor builder into @nuxt/builder and @nuxt/webpack (#​4171)
  • Move @nuxtjs/babel-preset-app into nuxt mono-repo and republish it as @nuxt/babel-preset-app (#​4205)
  • Move common config to @nuxt/config (#​4212)
  • Packaging and development improvements (#​4193)
  • Extract eslint-config into own package (#​4108)
  • Several test utils cleanups (MR #​4180)

v2.3.0

Compare Source


Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever MR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this MR and you won't be reminded about this update again.


  • If you want to rebase/retry this MR, check this box

This MR has been generated by Renovate Bot.

Merge request reports