iT邦幫忙

2019 iT 邦幫忙鐵人賽

DAY 11
1
Modern Web

Nuxt - 使用 Vue.js 做 SSR 的第一哩路系列 第 11

11. Nuxt 頁面驗證和錯誤顯示

  • 分享至 

  • xImage
  •  

接下來幾篇都屬頁面客製,這篇講「Nuxt 發生錯誤時,他怎麼判斷與反應」

先回顧這張流程圖

Nuxt 收到請求時,會經過這麼多步驟

而碰到不可預期的錯誤頁面驗證噴錯,Nuxt 會顯示錯誤預設頁面,這通常對應到 404、500

每個頁面元件都可按需要調整,藉由調整頁面元件的 validate callback,以符合 User Story 的邏輯

例如判斷 /users/:id 是不是合法 id,或者驗證權限

validate({ params, query, store }) {
	/* */
    return /^\d+$/.test(params.id);
}

詳細我就不詳述了,可參考 API 文件

為了開發方便,先將驗面驗證為 false (總是噴錯)

<template>
	<!-- pages/login.vue -->
</template>

<script>
	export default {
        /* ... */
        validate() {
			return false;
		}
	}
</script>

看起來落落大方,放在 .nuxt/template/components/nuxt-error.vue

<template>
  <div class="__nuxt-error-page">
    <div class="error">
      <svg xmlns="http://www.w3.org/2000/svg" width="90" height="90" fill="#DBE1EC" viewBox="0 0 48 48"><path d="M22 30h4v4h-4zm0-16h4v12h-4zm1.99-10C12.94 4 4 12.95 4 24s8.94 20 19.99 20S44 35.05 44 24 35.04 4 23.99 4zM24 40c-8.84 0-16-7.16-16-16S15.16 8 24 8s16 7.16 16 16-7.16 16-16 16z" /></svg>

      <div class="title">{{ message }}</div>
      <p v-if="statusCode === 404" class="description">
        <nuxt-link class="error-link" to="/"><%= messages.back_to_home %></nuxt-link>
      </p>
      <% if(debug) { %>
      <p class="description" v-else><%= messages.client_error_details %></p>
      <% } %>

      <div class="logo">
        <a href="https://nuxtjs.org" target="_blank" rel="noopener"><%= messages.nuxtjs %></a>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  name: 'nuxt-error',
  props: {
    error: {
      type: Object,
      default: null
    }
  },
  head() {
    return {
      title: this.message,
      meta: [
        {
          name: 'viewport',
          content: 'width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no'
        }
      ]
    }
  },
  computed: {
    statusCode() {
      return (this.error && this.error.statusCode) || 500
    },
    message() {
      return this.error.message || `<%= messages.client_error %>`
    }
  }
}
</script>

<style>
.__nuxt-error-page {
  padding: 1rem;
  background: #F7F8FB;
  color: #47494E;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  font-family: sans-serif;
  font-weight: 100 !important;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.__nuxt-error-page .error {
  max-width: 450px;
}
.__nuxt-error-page .title {
  font-size: 1.5rem;
  margin-top: 15px;
  color: #47494E;
  margin-bottom: 8px;
}
.__nuxt-error-page .description {
  color: #7F828B;
  line-height: 21px;
  margin-bottom: 10px;
}
.__nuxt-error-page a {
  color: #7F828B !important;
  text-decoration: none;
}
.__nuxt-error-page .logo {
  position: fixed;
  left: 12px;
  bottom: 12px;
}
</style>

但為了符合網站一致性,得按照設計稿調整

這時你只需產生 layouts/error.vue ,調整這頁即可

<template>
  <div class="container">
    <h1 v-if="error.statusCode === 404">Page not found</h1>
    <h1 v-else>An error occurred</h1>
    <nuxt-link to="/">Home page</nuxt-link>
  </div>
</template>

<script>
export default {
  props: ['error'],
  layout: 'blog' // you can set a custom layout for the error page
}
</script>


上一篇
10. Nuxt 頁面元件簡化過程
下一篇
12. Nuxt 客製頁面效果 - 讀取(Loading)
系列文
Nuxt - 使用 Vue.js 做 SSR 的第一哩路32
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言