news 2026/6/10 14:46:47

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/6/10 13:21:36

基于FLUX.1-dev的文生图技术博客:提升提示词遵循度的秘诀

基于FLUX.1-dev的文生图技术&#xff1a;如何让AI真正“听懂”你的每一句话 在如今的生成式AI浪潮中&#xff0c;我们早已习惯了输入一段文字&#xff0c;几秒后便收获一幅惊艳图像。但你是否也遇到过这样的情况——明明写得清清楚楚&#xff1a;“一只戴着墨镜的柯基狗站在滑板…

作者头像 李华
网站建设 2026/6/10 12:49:48

Postman脚本批量转接口自动化用例

部署运行你感兴趣的模型镜像一键部署 作者之前已经开发了一个生成接口用例的工具 - API接口用例生成器&#xff0c;即将现有的 Postman 脚本转化为接口用例。本篇介绍另一款最近刚开发并项目落地的工具&#xff0c;将 Postman 的 json 脚本文件可以批量转换生成接口用例 - API…

作者头像 李华
网站建设 2026/6/9 18:49:49

线性表之链式栈

插入操作和删除操作均在链表头部进行&#xff0c;链表尾部就是栈底&#xff0c;栈顶指针就是头指针不需要预先分配固定大小动态增长和收缩typedef int data_t ; /*定义栈中数据元素数据类型*/ typedef struct node_t {data_t data ; /*数据域*/struct node_t *ne…

作者头像 李华
网站建设 2026/6/9 23:10:02

岩土颗粒粗糙度计算,采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度,算术平均粗糙度

岩土颗粒粗糙度计算&#xff0c;采用傅里叶展开。 matlab源代码 生成颗粒均方根粗糙度&#xff0c;算术平均粗糙度。 方法来自《非规则颗粒形态表征与离散元模拟方法的研究》清华大学出版社 matalb源代码傅里叶展开在岩土颗粒形态分析中的应用挺有意思。咱们今天直接上干货&…

作者头像 李华
网站建设 2026/6/9 19:30:32

GTN损伤模型在金属成型中的实战改造手记

修正的考虑剪切和静水压力的各向异性和各向同性 GTN 模型 Abaqus_Vumat 子程序以及跑通的案例&#xff0c;包括 三个子程序 for 文件&#xff08;各向同性&#xff0c;自己推导修改以及各向异性&#xff09; 、cae 文件和 inp 文件等&#xff0c;还有一些论文资料。 注&#x…

作者头像 李华