在新的App Router中,在NextJS 13.4中执行简单的PUT的正确方法是什么?以前使用NextAPIRequest、NextAPIResponse、使用if(req.method = 'PUT')、通过const { id } = request.query;从URL中提取参数以及使用NextAPIResponse抛出错误消息来执行删除的方法似乎已经过时了。
zsohkypk1#
这里是NextJS 13.4中更新的PUT API,使用了新的app routing,包含了错误消息。为了使示例更加清晰,我将包含一个对supabase client的调用;您调用的API可以不同,但您可以看到错误消息等。
app routing
supabase client
// FILE NAME /app/api/tacos/route.js import { NextResponse } from 'next/server'; import supabase from '../../supabase/client'; export async function PUT(request) { try { // ! OLD WAY // const { id, newData } = req.body; // ! OLD WAY // const dataOldWay = JSON.parse(request.body); // ! OLD WAY const { id, newData } = await request.json(); const { data: insertedData, error } = await supabase.from("my_table").update(newData).eq("id", id).select(); if (error) { console.log("error catch"); return NextResponse.json({ error: "Internal Server Error" }, { status: 500 }); // ! THE FOLLOWING DOES NOT WORK - will assume and return a status 200 response // return NextResponse.json({ error: 'Internal Server Error', status: 500 }); } return NextResponse.json({ insertedData }); } catch { return NextResponse.json({ error: 'Catch Error - Internal Server Error' }, { status: 500 }); } }
字符串为清楚起见,在Typescript中,此函数签名将为export async function PUT(request: NextRequest) {阅读更多关于路由处理程序here的信息。为了完整起见,这里有一个非常简单的函数,我在客户端应用程序中使用它来调用这个API。
export async function PUT(request: NextRequest) {
// This is being called from a Page in your React app // 'use client'; // import React from 'react`; // ... define your other import statements here const putData = async () => { const id = "23423dfe-2343-2323223-232323-232323223"; const data = { key1: "value1", key2: 22222222 }; try { const response = await fetch("/api/saveCalculation", { method: "PUT", body: JSON.stringify({id, data}), headers: { "Content-Type": "application/json", }, }); if (response.ok) { console.log("OKAY"); const data = await response.json(); console.log("putData - data updated", responseData); } else { // Handle the error console.log("NOT OKAY"); const data = await response.json(); console.log("putData - data NOT updated", responseData); } } catch (error) { console.error("Error", error); const data = await response.json(); console.log("putData - try/catch - error", responseData); } };
型注意:你当然可以在代码中更高的位置合并responseData声明,但我保持了它的简单性,为了可读性,使用了更小的范围。
1条答案
按热度按时间zsohkypk1#
这里是NextJS 13.4中更新的PUT API,使用了新的
app routing
,包含了错误消息。为了使示例更加清晰,我将包含一个对
supabase client
的调用;您调用的API可以不同,但您可以看到错误消息等。字符串
为清楚起见,在Typescript中,此函数签名将为
export async function PUT(request: NextRequest) {
阅读更多关于路由处理程序here的信息。
为了完整起见,这里有一个非常简单的函数,我在客户端应用程序中使用它来调用这个API。
型
注意:你当然可以在代码中更高的位置合并responseData声明,但我保持了它的简单性,为了可读性,使用了更小的范围。