nextjs配置端口以及不同的环境变量

一、安装cross-env

1、解决方案一

直接设置公开变量:

复制代码
{
  "dev": "cross-env NEXT_PUBLIC_APP_ENV=development next dev -p 4400",

  "dev:test": "cross-env NEXT_PUBLIC_APP_ENV=test next dev -p 4400",

  "build:prod": "cross-env NEXT_PUBLIC_APP_ENV=production next build"
}

然后:

复制代码
process.env.NEXT_PUBLIC_APP_ENV

就会得到:

复制代码
development
test
production

2、解决方案二(推荐)

脚本:

复制代码
{
  "dev": "cross-env APP_ENV=development next dev",

  "dev:test": "cross-env APP_ENV=test next dev",

  "build:prod": "cross-env APP_ENV=production next build"
}

然后在 next.config.ts

复制代码
import type { NextConfig } from 'next';

const APP_ENV = process.env.APP_ENV ?? 'development';

console.log('APP_ENV=', APP_ENV);

const nextConfig: NextConfig = {
  env: {
    NEXT_PUBLIC_APP_ENV: APP_ENV,
  },
};

export default nextConfig;

重启开发服务器。

此时:

复制代码
pnpm dev:test

控制台:

复制代码
APP_ENV=test

浏览器:

复制代码
process.env.NEXT_PUBLIC_APP_ENV

复制代码
test

3、如果仍然显示 development

检查 .env.development 是否有:

复制代码
NEXT_PUBLIC_APP_ENV=development

因为 next.config.tsenv 配置和 .env 文件可能会同时存在。

最简单的做法是:

删除所有 .env* 文件里的 NEXT_PUBLIC_APP_ENV

只保留:

复制代码
NEXT_PUBLIC_API_URL=...

然后统一由:

复制代码
// next.config.ts
env: {
  NEXT_PUBLIC_APP_ENV: APP_ENV,
}

生成。

这样不会出现:

复制代码
.env.development => development
cross-env => test

两个来源打架的问题。

二、根据 APP_ENV 注入对应的 API 地址

复制代码
const config = {
  development: {
    apiUrl: 'https://dev-api.example.com',
  },
  test: {
    apiUrl: 'https://test-api.example.com',
  },
  production: {
    apiUrl: 'https://api.example.com',
  },
};

const APP_ENV = process.env.APP_ENV ?? 'development';

export default {
  env: {
    NEXT_PUBLIC_APP_ENV: APP_ENV,
    NEXT_PUBLIC_API_URL: config[APP_ENV].apiUrl,
  },
};

这样:

复制代码
process.env.NEXT_PUBLIC_API_URL

才会随着:

复制代码
pnpm dev
pnpm dev:test
pnpm build:prod

自动切换。

对于 Next.js 项目,我通常会把所有环境配置集中到 src/config/env.ts,并通过 APP_ENV → next.config.ts → NEXT_PUBLIC_* 这一层映射来管理,而不是在多个 .env 文件里维护同一套前端配置。这样类型更安全,也更容易排查问题。

三、配置端口以及开发启动打开默认浏览器

先安装:

复制代码
pnpm add -D concurrently wait-on open-cli

然后修改 package.json

复制代码
{
  "scripts": {
    "dev": "concurrently \"next dev -p 4400\" \"wait-on http://localhost:4400 && open-cli http://localhost:4400\"",

    "dev:test": "concurrently \"cross-env APP_ENV=test next dev -p 4400\" \"wait-on http://localhost:4400 && open-cli http://localhost:4400\""
  }
}

启动:

复制代码
pnpm dev

或者:

复制代码
pnpm dev:test

服务启动完成后会自动打开默认浏览器访问:

复制代码
http://localhost:4400

为了避免端口写两遍,推荐抽成变量:

复制代码
{
  "scripts": {
    "dev": "cross-env PORT=4400 concurrently \"next dev -p %PORT%\" \"wait-on http://localhost:%PORT% && open-cli http://localhost:%PORT%\""
  }
}

但这在 Windows 和 macOS/Linux 上变量写法不同,所以实际项目里很多人直接写死:

复制代码
{
  "scripts": {
    "dev": "concurrently \"next dev -p 4400\" \"wait-on http://localhost:4400 && open-cli http://localhost:4400\""
  }
}

最简单也最稳定。

如果你已经有开发、测试、生产环境脚本,我推荐这样整理:

复制代码
{
  "scripts": {
    "dev": "concurrently \"cross-env APP_ENV=development next dev -p 4400\" \"wait-on http://localhost:4400 && open-cli http://localhost:4400\"",

    "dev:test": "concurrently \"cross-env APP_ENV=test next dev -p 4400\" \"wait-on http://localhost:4400 && open-cli http://localhost:4400\"",

    "build:test": "cross-env APP_ENV=test next build",
    "build:prod": "cross-env APP_ENV=production next build",

    "start:test": "cross-env APP_ENV=test next start -p 4400",
    "start:prod": "cross-env APP_ENV=production next start -p 4400"
  }
}

这样执行 pnpm devpnpm dev:test 时都会自动打开浏览器。

相关推荐
一个扣子1 天前
第二十四篇:新建React组件:从自然语言描述到完整前端模块
react·组件开发·实战案例·claud code·前端自动化
一起学开源2 天前
一文读懂 ReAct 范式:让 AI Agent 真正学会“思考+行动“
java·javascript·react.js·ecmascript·react·alibaba·智能体开发
jingling5552 天前
自建技术博客实战(三):工具专栏——地图定位、声音复刻与 rembg 抠图
android·开发语言·前端·ai·nextjs
格桑阿sir2 天前
14-大模型智能体开发工程师:ReAct推理-行动框架
ai·大模型·llm·agent·react·智能体·推理模型
超级战斗鸡2 天前
React Context Menu — 轻量级零依赖右键菜单组件
react
Richown4 天前
用 Three.js + React 打造一个赛博朋克风格的 3D 作品集页面
区块链·react
qcx236 天前
【系统学AI】08 Plan-then-Execute范式:先想好再做,比ReAct强在哪
前端·人工智能·react.js·ai·react·plan execute
JaydenAI7 天前
[MAF预定义ChatClient中间件-02]FunctionInvokingChatClient——实现ReAct循环和人机交互的大功臣
ai·人机交互·agent·react·hitl·maf·chatclient中间件
花月C9 天前
LangGraph 状态机与 ReAct Agent
python·agent·react·langgragh