Maison > Questions et réponses > le corps du texte
J'ai une fonction myFetch qui est un wrapper autour de fetch pour ajouter un jeton dans l'en-tête
import clientCookies from "js-cookie"; import {cookies} from "next/headers"; const myFetch = async (...args) => { let token if (typeof window === "undefined") { // client side token = clientCookies.get("authToken") } else { // server side serverCookies = cookies() token = serverCookies.get("authToken").value } args[1].headers = {"Authorization": `bearer ${token}`} const res = await fetch(...args) const data = await res.json() return data }
Mais j'obtiens une erreur lors de l'appel de cette fonction côté client
You're importing a component that needs next/headers. That only works in a Server Component but one of its parents is marked with "use client", so it's a Client Component. Learn more: https://nextjs.org/docs/getting-started/react-essentials
Existe-t-il un moyen d'"importer des {cookies} uniquement à partir du côté serveur 'next/headers'"
P粉4706452222024-04-02 00:52:26
Vous pouvez importer conditionnellement chaque module en fonction du type actuel de l'objet fenêtre. Si non défini ; importer le module serveur, sinon le module client :
const myFetch = async (...args) => { let token; if (typeof window === "undefined") { const { default: clientCookies } = await import("js-cookie"); token = clientCookies.get("authToken"); } else { const { cookies: serverCookies } = await import("next/headers"); token = serverCookies().get("authToken").value; } args[1].headers = { Authorization: `bearer ${token}` }; const res = await fetch(...args); const data = await res.json(); return data; };