后端路由在 url 匹配路径时即被触发,无论请求来自浏览器直接导航还是前端 fetch;但二者目的、行为和适用场景截然不同:导航用于页面跳转与 html 渲染,fetch 用于程序化数据交互与动态 ui 更新。
后端路由(如 Express 中的 app.get('/restaurants', ...))本质上是服务器对符合特定 HTTP 方法 + 路径规则的请求的响应逻辑。只要客户端(无论是浏览器、curl 还是 JavaScript 的 fetc

当你在浏览器地址栏输入 http://localhost:3000/restaurants 并回车,浏览器确实向服务端发送了 GET 请求,服务端也正确返回了 JSON 数据(如 ALL_RESTAURANTS 数组)。但此时:
// 浏览器直接访问 /restaurants 时可能显示(不友好):
[
{"id":"0b65fe74-...","name":"Taco Express"},
{"id":"869c848c-...","name":"Pho Vinason"}
]前端调用 fetch('/restaurants') 同样触发同一后端路由,但关键差异在于控制权回到 JavaScript:
const getRestaurants = async () => {
try {
const response = await fetch(`${API_ENDPOINT}/restaurants`);
// 可主动检查状态码
if (!response.ok) throw new Error(`HTTP ${response.status}`);
const restaurants = await response.json();
// ✅ 动态渲染:插入到 DOM 列表中
renderRestaurantList(restaurants);
// ✅ 条件处理:仅显示评分 > 4 的餐厅
const topRated = restaurants.filter(r => r.rating && r.rating > 4);
// ✅ 错误捕获:网络失败、解析异常、空数组等均可统一处理
return restaurants;
} catch (err) {
console.error("加载餐厅列表失败:", err);
showErrorMessage("暂无法获取餐厅信息,请稍后重试");
}
};后端路由是守门人,匹配即执行; 浏览器导航是“用户视角”的请求入口,适合跳转页面;fetch 是“程序视角”的数据管道,负责驱动动态界面、处理业务逻辑、保障用户体验。 二者协同工作——路由提供能力,fetch(或 Axios 等)赋予前端调度该能力的自由度。