版本:next.js@15.0.0-canary.75
1. 用服务端的方式通过fetch获取数据报错
Error: connect ECONNREFUSED
import { type ClassValue, clsx } from 'clsx';
import { twMerge } from 'tailwind-merge';
const baseUrl = 'http://localhost:23820/';
export function cn(...inputs: ClassValue[]) {
return twMerge(clsx(inputs));
}
export const request = async (url: string, params?: any) => {
const nextUrl = `${baseUrl}${url}`;
try {
const res = await fetch(nextUrl, {
headers: {
accept: 'application/json'
},
cache: 'no-store',
...params
});
const ret = await res.json();
return ret;
} catch (error) {
console.warn('request error:', error);
}
};
我用postman和curl命令都是没问题的,但是用这种方式不行,还尝试了umirc代理跟nest.js项目中用fetch,axios请求都是报这个错,但是请求nest.js接口const products = await request('http://localhost:3000/products');
没有问题,最后尝试了将地址改为http://127.0.0.1:23820/
,接口成功的返回数据了。感觉是nodejs的问题,于是查阅,ECONNREFUSED on NodeJS 18 #1624,查看下我的nodejs版本为v18.20.4,的确如issue中所说,是nodejs的dsn策略优先查找ipv6,但是服务端只监测IPv4的地址,导致匹配不上。另一个csr项目为了不让写在umirc文件中的服务端地址提交到github公开仓库里,昨天对本机的nginx做了代理,试了很多次不起作用,顺着这个思路将umirc代理的地址从localhost改为127.0.0.1就好了。
2. server组件调用client组件报错
错误信息:
Creating promises inside a Client Component or hook is not yet supported, except via a Suspense-compatible library or framework.
解决办法:
在client组件中用useState存数据,而不是用server的async方式
以下都是在基于next.js@15.0.1
3. pnpm run build 报错
system/page.tsx
import {
Card,
CardContent,
CardDescription,
CardHeader,
CardTitle
} from '@/components/ui/card';
import { showConfigs, showVariables } from '../actions';
export default async function ProductsPage() {
const configs = await showConfigs();
const variables = await showVariables();
return (
<div>
</div>
);
}
actions.tsx
export const showConfigs = async () => {
try {
const x = await get(`${ApiUrl.configs}`);
return x;
} catch (error) {
console.log('🚀 ~ error:', error);
unstable_rethrow(error);
return {};
}
};
export const showVariables = async () => {
try {
const x = await get(`${ApiUrl.variables}/global`);
return x;
} catch (error) {
unstable_rethrow(error);
console.log('🚀 ~ error:', error);
return {};
}
};
request.ts
const baseUrl = 'http://127.0.0.1:23820/';
export const request = async (
url: string,
params: Record<string, unknown> = {},
method: string = 'GET'
) => {
let nextUrl = `${baseUrl}${url}`;
const options: RequestInit = {
headers: {
accept: 'application/json'
},
cache: 'no-store',
method
};
if (method === 'GET') {
nextUrl +=
'?' + new URLSearchParams(params as Record<string, string>).toString();
} else {
options.body = JSON.stringify(params);
}
try {
const res = await fetch(nextUrl, options);
const ret = await res.json();
return ret;
} catch (error) {
console.warn('request error:', error);
}
};
export const get = (url: string, params?: Record<string, string>) =>
request(url, params, 'GET');
报错信息:
搜索:
Dynamic server usage: Page couldn't be rendered statically because it used nextUrl.searchParams
in Next.js version 14
根据上文提到的一句话 找到了 unstable_rethrow 文档,翻阅了我的代码果然在request.ts中发现了cache: 'no-store'
, 将这句删掉后重新构建就没问题了。
4. pnpm run build 报权限错误
- next.config.js 设置 output: 'standalone'
- 运行 pnpm run build 报错
解决办法:
pnpm and output standalone return EPERM: operation not permitted, symlink #52244
问题是解决了,根本原因好像是,fs.symlink
的问题
Windows with pnpm and output standalone not work properly #50803
5. node server.js 页面样式错乱
打开控制台,出现大量的404
查阅 All static assets (js/css/media) in Standalone mode become 404 #49283 需要将.next/static拷贝到standalone/public/_next/static,如下
6. next.js 目前还不支持static export模式(CSR)下的动态路由
2025.1.14
Support dynamic routes (with dynamic params) in static export mode #55393 这里展开了激烈的讨论,有人通过query string的方式来代替动态路由。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。