溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

nuxt3中的server?routes如何使用

發(fā)布時間:2022-05-23 11:19:03 來源:億速云 閱讀:417 作者:iii 欄目:開發(fā)技術(shù)

這篇“nuxt3中的server routes如何使用”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“nuxt3中的server routes如何使用”文章吧。

nuxt3在后端服務(wù)器這塊引入了Nitro框架,感興趣的朋友可以移步到官方網(wǎng)站進(jìn)行了解和學(xué)習(xí),個人感覺類似nodejs框架里面的express 和 koa吧,只是可能更輕量吧。

在創(chuàng)建api之前,我們首先需要在根目錄下創(chuàng)建一個server 目錄,nuxt3會自動檢索目錄中的api目錄,routes目錄以及middleware目錄,并根據(jù)這些目錄里面的文件名自動創(chuàng)建對應(yīng)的api。

比如我們想要創(chuàng)建一個api/hello的api,首先我們需要在server 目錄下創(chuàng)建api目錄,并且在api目錄下創(chuàng)建一個名為hello.ts。

// server/api/hello.ts
export default defineEventHandler((event) => {
  return {
    api: 'works'
  }
})

注意:每個文件都需要導(dǎo)出一個默認(rèn)的命名為defineEventHandler的函數(shù),這樣我們在代碼中就可以通過 await $fetch('/api/hello')這種方式進(jìn)行調(diào)用了。通過defineEventHandler可以返回json格式的數(shù)據(jù),也可以返回一個Promise,也可以直接使用event.res.end()進(jìn)行返回。

通過在server/api目錄下創(chuàng)建文件的方式,nuxt會自動生成/api/filename 這樣的訪問路徑,如果我們在開發(fā)過程中不想使用/api/filename這樣的訪問路徑,而是希望可以直接通過 /filename這種的文件路徑,那么我們可以在server目錄下創(chuàng)建routes目錄,并且在該目錄下創(chuàng)建對應(yīng)的文件即可。

// server/routes/hello.ts
export default defineEventHandler(() => 'Hello World!')

此時我們就可以直接使用await $fetch('/hello')進(jìn)行訪問了,是不是很方便?

如果想在nuxt3中使用中間件,那么我們需要在server目下下創(chuàng)建middleware目錄,并將自己創(chuàng)建的中間件文件放置在該目錄下

中間件處理程序,會應(yīng)用在每一個api路由之前,它可以用來增加路由檢測、增加請求header信息或者記錄請求日志,也可以用來擴(kuò)展event請求對應(yīng)

// server/middleware/log.ts
export default defineEventHandler((event) => {
  console.log('New request: ' + event.req.url) // 打印請求日志
})
// server/middleware/auth.ts
export default defineEventHandler((event) => {
  event.context.auth = { user: 123 } // 擴(kuò)展event上下文
})

匹配路由參數(shù)

server routes 可以處理動態(tài)路由,在文件名中間使用中括號的方式,這點兒和前端動態(tài)路由類似,比如server/api/hello-[name].ts,訪問動態(tài)路由參數(shù)可以通過event.context.params對象進(jìn)行訪問。

export default defineEventHandler(event => `Hello, ${event.context.params.name}!`)

代碼中就可以通過$fetch('/api/hello/nuxt')這種方式進(jìn)行調(diào)用了

以上方式創(chuàng)建的路由默認(rèn)都是get方式進(jìn)行訪問,如果我們想要創(chuàng)建post,put,delete等方式的請求處理函數(shù)應(yīng)該怎么操作呢?

Http方法匹配

我們可以創(chuàng)建以.get、.post、.put、.delete等為后綴的文件名來匹配對應(yīng)的Http method

// server/api/test.get.ts
export default defineEventHandler(() => 'Test get handler')
/// server/api/test.post.ts
export default defineEventHandler(() => 'Test post handler')

以上兩個文件分別以.get 和 .post后綴,那么在代碼請求中就只能使用相對應(yīng)的get、post方式進(jìn)行請求,如果換成其他方式,直接返回404 error

處理請求體

post請求中,一般都會在請求體里面?zhèn)魅胍恍﹨?shù),獲取請求體參數(shù)可以通過以下這種方式

// server/api/submit.post.ts
export default defineEventHandler(async (event) => {
    const body = await useBody(event)
    return { body }
})

前端傳入?yún)?shù)可以通過以下方式

$fetch('/api/submit', { method: 'post', body: { test: 123 } })

注意:此時我們創(chuàng)建了一個submit.post的文件用以處理post請求,此時我們使用useBody可以接收到前端傳來的請求參數(shù)。但如果我們使用get方式請求該API,那么接口會拋出r405 Method Not Allowed HTTP error

處理get請求路由參數(shù)

例如:/api/query?param1=a&param2=b

// server/api/query.get.ts
export default defineEventHandler((event) => {
  const query = useQuery(event)
  return { a: query.param1, b: query.param2 }
})

以上就是關(guān)于“nuxt3中的server routes如何使用”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI