news 2026/4/3 19:47:48

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
React编码时,什么时候用js文件,什么时候用jsx文件?

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

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

示例:

// Component.jsx import React from 'react'; const MyComponent = () => { return ( <div> <h1>Hello World</h1> </div> ); }; export default MyComponent;
  1. 使用 JS 文件的情况
    • 工具函数
    • 常量定义
    • 配置文件
    • API 调用
    • 纯数据处理逻辑
    • 自定义 hooks(虽然包含 JSX,但通常使用 .js 扩展名)

示例:

// utils.jsexportconstformatDate=(date)=>{returnnewDate(date).toLocaleDateString();};exportconstvalidateEmail=(email)=>{return/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email);};
// constants.jsexportconstAPI_ENDPOINTS={USERS:'/api/users',POSTS:'/api/posts'};exportconstSTATUS={PENDING:'pending',APPROVED:'approved',REJECTED:'rejected'};
  1. 最佳实践建议

    a)组件文件

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

    b)逻辑文件

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

    c)Hooks 文件

    • 通常使用.js扩展名
    • 即使内部使用了 JSX,也推荐使用 .js
    • 示例:
    // hooks/useCustomHook.jsimport{useState}from'react';exportconstuseCustomHook=()=>{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
  1. 特殊情况

    a)配置文件

    • 即使包含类似 JSX 的配置,也使用.js
    // config/routes.jsexportconstroutes=[{path:'/',component:Home}];

    b)测试文件

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

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

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

总结:

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 3:31:04

Windows剪贴板的超级增强器,提升你的工作效率

Windows剪贴板的超级增强器,提升你的工作效率 在日常的电脑操作中,复制粘贴无疑是使用频率极高的功能。然而,Windows自带的剪贴板功能却显得捉襟见肘,每次复制新内容时,旧的内容就会被无情地覆盖。这对于需要频繁切换或重复使用之前复制内容的用户来说,无疑是一个巨大的痛…

作者头像 李华
网站建设 2026/3/28 9:59:22

@AutoConfigureBefore 与 @AutoConfigureAfter

目录 1、介绍 1.1、设计目的 1.2、定义 1.3、作用域 1.4、设计限制 2、应用 2.1、使用场景 2.2、工作原理 2.3、实战示例 3、常见误区与最佳实践 3.1、最佳实践 3.2、常见误区 3.3、与其他顺序控制注解对比 前沿 控制 Spring Boot 自动配置顺序&#xff1a; “我…

作者头像 李华
网站建设 2026/4/2 3:12:11

Qt----事件简述

目录1&#xff0c;事件的概念2&#xff0c;事件循环3&#xff0c;父子控件之间事件的传递处理4&#xff0c;事件过滤器1&#xff0c;事件的概念 定义&#xff1a; 事件是应用程序内部发生的事情或应用程序需要知道的外部事件的结果。 事件和信号的区别&#xff1a; 事件是由外…

作者头像 李华
网站建设 2026/4/3 3:04:48

AXI-A7.4.3 Atomic transactions attributes

一、atomic transactions are as follows: 1. AWLEN和AWSIZE指定写数据的字节数(对于AtomicCompare需包含比较值和交换值) AWLEN(突发长度)和AWSIZE(每次传输的字节数)共同决定了原子事务中写数据的总字节数。对于大多数原子事务,这指的是操作数的大小;但对于AtomicCom…

作者头像 李华
网站建设 2026/4/1 17:29:38

内存泄漏怎么定位和解决?core dump有哪些信息?

一、为什么会内存泄漏&#xff1f;常见场景&#xff1a;音频播放反复malloc缓冲区未freeMQTT断线重连时不断分配内存呢解析JSON字符串频繁申请堆空间回调注册后未注销导致上下文无法释放使用全局链表或队列但不清除节点二、如何定位内存泄漏&#xff1f;1、添加内存监控接口在T…

作者头像 李华
网站建设 2026/4/1 9:25:47

STL deque 的详细特征

STL deque 的详细特征 基本特性 #include <deque> using namespace std;deque<int> dq; // 声明一个int类型的双端队列 双端队列&#xff1a;允许在两端进行高效插入和删除动态数组&#xff1a;支持随机访问&#xff0c;可以像数组一样通过下标访问内存结构&a…

作者头像 李华