在React.js中工作时,有一些事情让我感到非常困惑。

在互联网上有很多使用.js文件的React的例子,但也有很多人使用.jsx文件。

我读过JSX文件,我的理解是它们只是让您在JavaScript中编写HTML标记。 但同样的东西也可以写在JS文件中。

那么。js和。jsx之间的实际区别是什么呢?


当前回答

JSX标签(<Component/>)显然不是标准的javascript,如果你把它们放在一个裸的<script>标签中,就没有特殊的意义。因此所有包含它们的React文件都是JSX而不是JS。

按照惯例,React应用程序的入口点通常是.js而不是.jsx,即使它包含React组件。也可以是。jsx。任何其他JSX文件通常都有. JSX扩展名。

在任何情况下,存在模糊性的原因是,最终扩展并不重要,因为转译器乐于咀嚼任何类型的文件,只要它们实际上是JSX。

我的建议是:别担心。

其他回答

在大多数情况下,它只需要转译器/捆绑器,它可能不会被配置为与JSX文件一起工作,而是与JS一起工作!所以你被迫使用JS文件而不是JSX。

因为react只是一个javascript库,所以你在JSX和JS之间选择没有区别。它们是完全可以互换的!

在某些情况下,用户/开发人员也可能会选择JSX而不是JS,因为代码高亮显示,但大多数较新的编辑器也可以正确地查看JS文件中的react语法。

除了上面提到的JSX标签不是标准的javascript之外,我使用.jsx扩展名的原因是Emmet仍然可以在编辑器中工作——你知道,这个有用的插件可以扩展html代码,例如ul>li

<ul>
  <li></li>
</ul>

正如其他人提到的,JSX不是一个标准的Javascript扩展。最好基于.js命名应用程序的入口点,对于其他组件,您可以使用.jsx。

我有一个重要的原因,为什么我使用. jsx作为所有组件的文件名。 实际上,在一个有大量代码的大型项目中,如果我们将所有React的组件都设置为.jsx扩展名,那么在整个项目中导航到不同的javascript文件(如helper,中间件等)时会更容易,而且你知道这是一个React组件,而不是其他类型的javascript文件。

JSX不是标准的JavaScript,根据Airbnb风格指南“eslint”可以考虑这种模式

// filename: MyComponent.js
function MyComponent() {
  return <div />;
}

作为警告,如果您将文件命名为MyComponent。JSX它将通过,除非你编辑eslint规则 你可以在这里查看风格指南

如前所述,如果用.jsx或.js创建文件,两者没有区别。

我想带来另一种期望,即在创建组件时将文件创建为.jsx。

这不是强制性的,而是一种我们可以遵循的架构方法。因此,在大型项目中,我们将组件划分为表示组件或容器组件。简单地说,在容器组件中,我们编写逻辑来获取组件的数据,并使用道具渲染表示组件。在表示组件中,我们通常不编写功能逻辑,表示组件用于表示带有所需道具的UI。

所以,如果你在React文档中检查JSX的定义。

它说,

const element = <h1>Hello, world!</h1>; It is called JSX, and it is a syntax extension to JavaScript. We recommend using it with React to describe what the UI should look like. JSX may remind you of a template language, but it comes with the full power of JavaScript. JSX produces React “elements”. Instead of artificially separating technologies by putting markup and logic in separate files, React separates concerns with loosely coupled units called “components” that contain both. React doesn’t require using JSX, but most people find it helpful as a visual aid when working with UI inside the JavaScript code. It also allows React to show more useful error and warning messages.

它的意思是,它不是强制性的,但你可以考虑用'来创建表示组件。jsx',因为它实际上绑定了UI的道具。容器组件,如.js文件,包含获取数据的逻辑。

这是在创建.jsx或.js文件时可以遵循的约定,在逻辑上和物理上分离代码。