React编码时,什么时候用js文件,什么时候用jsx文件?

在 React 项目中,JSX 和 JS 文件的选择主要取决于文件的用途和内容。以下是详细说明:

  1. 使用 JSX 文件的情况
    • React 组件文件
    • 包含 JSX 语法(类似 HTML 的语法)
    • 需要渲染 UI 的文件

示例:

jsx 复制代码
// Component.jsx
import React from 'react';

const MyComponent = () => {
  return (
    <div>
      <h1>Hello World</h1>
    </div>
  );
};

export default MyComponent;
  1. 使用 JS 文件的情况
    • 工具函数
    • 常量定义
    • 配置文件
    • API 调用
    • 纯数据处理逻辑
    • 自定义 hooks(虽然包含 JSX,但通常使用 .js 扩展名)

示例:

javascript 复制代码
// utils.js
export const formatDate = (date) => {
  return new Date(date).toLocaleDateString();
};

export const validateEmail = (email) => {
  return /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);
};
javascript 复制代码
// constants.js
export const API_ENDPOINTS = {
  USERS: '/api/users',
  POSTS: '/api/posts'
};

export const STATUS = {
  PENDING: 'pending',
  APPROVED: 'approved',
  REJECTED: 'rejected'
};
  1. 最佳实践建议

    a) 组件文件

    • 使用 .jsx 扩展名
    • 包含 JSX 语法
    • 导出 React 组件

    b) 逻辑文件

    • 使用 .js 扩展名
    • 包含纯 JavaScript 代码
    • 不包含 JSX 语法

    c) Hooks 文件

    • 通常使用 .js 扩展名
    • 即使内部使用了 JSX,也推荐使用 .js
    • 示例:
    javascript 复制代码
    // hooks/useCustomHook.js
    import { useState } from 'react';
    
    export const useCustomHook = () => {
      const [state, setState] = useState(null);
      // hook 逻辑
      return { state, setState };
    };
  2. 项目结构示例

    src/
    components/
    Button.jsx
    Modal.jsx
    Form.jsx
    hooks/
    useAuth.js
    useApi.js
    utils/
    helpers.js
    constants.js
    validators.js
    services/
    api.js
    auth.js

  3. 特殊情况

    a) 配置文件

    • 即使包含类似 JSX 的配置,也使用 .js
    javascript 复制代码
    // config/routes.js
    export const routes = [
      {
        path: '/',
        component: Home
      }
    ];

    b) 测试文件

    • 通常使用 .test.js.spec.js
    • 即使测试 JSX 组件也使用 .js
  4. 团队约定

    • 保持一致性最重要
    • 在团队内部统一规范
    • 可以在 .eslintrc 中配置规则
  5. 构建工具配置

    • 大多数现代构建工具(如 Webpack, Vite)都能正确处理两种扩展名
    • 可以在配置中指定解析规则

总结:

  • 包含 JSX 语法且是 React 组件 → 使用 .jsx
  • 纯 JavaScript 代码 → 使用 .js
  • 自定义 hooks → 推荐使用 .js
  • 保持团队内部一致性最重要

选择文件扩展名时,主要考虑文件的用途和内容,而不是严格的规定。关键是保持项目的一致性和可维护性。

相关推荐
kyriewen6 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
山河木马7 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
小林攻城狮7 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦7 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
tangdou3690986559 小时前
AI真好玩系列-2分钟快速了解DeepAgents | Quick Guide to DeepAgents in 2 Minutes
前端·javascript·后端
张元清9 小时前
React useIntersectionObserver Hook:懒加载与可见性检测(2026)
javascript·react.js
彭于晏爱编程9 小时前
纯 JS + Node,一个下午手搓了能读懂公司代码的 AI 助手,老板以为我转行了
前端·javascript
妙码生花10 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十四):眨眼小人登录页制作
前端·javascript·ai编程
妙码生花10 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十三):前端路由初始化
前端·javascript·ai编程
PBitW10 小时前
GPT训练我的第四天,被打惨了!!!😭😭😭
前端·javascript·面试