你知道 JS 中的模块导入有一个缺点吗?

开发 前端
在JavaScript中,导入语法会强制我们先指出要导入的项目(函数,类,变量),然后再指明模块的路径。这种方法不太友好。

1. 命名导入和自动完成

假设我编写了一个简单的JavaScript模块:

  1. // stringUtils.js 
  2. export function equalsIgnoreCase(string1, string2) { 
  3.   return string1.toLowerCase() === string2.toLowerCase(); 

模块stringUtils具有导出了一个函数exequalsIgnoreCase,该函数比较两个忽略大小写的字符串。

[[321374]]

看起来没啥问题,挺好的。

现在在 app.js 文件中导入函数 exequalsIgnoreCase

  1. / app.js 
  2. import { equalsIgnoreCase } from './stringUtils'; 
  3.  
  4. equalsIgnoreCase('Hello', 'hello'); // => true 

我们大多数会这样来引入:

你知道 JS 中的模块导入有一个缺点吗?

首先,您必须编写导入名称import {}。在此步骤中,IDE无法提供有关要导入的可用名称的任何建议。

然后,继续写入 from './stringUtils',然后移回大括号并展开自动完成以选择要导入的名称。

尽管 ES6 模块优点很多,但导入模块语法使自动完成功能难以使用。

2. Python 中的模块

现在让我们尝试在 Python 中导入命名组件。它有同样的问题吗?

下面用 Python 实现的相同模块stringUtils和函数equalsIgnoreCase:

  1. # stringUtils.py 
  2. def equalsIgnoreCase(string1, string2): 
  3.   return string1.lower() == string2.lower() 

在 Python 中,不必显式地指出要导出的函数。

现在,在另一个Python模块app内部,将stringUtils导入equalsIgnoreCase函数:

你知道 JS 中的模块导入有一个缺点吗?

在Python中,首先指出要从:from stringUtils哪里导入的模块。

如果你想知道可以导入的函数,编辑器已经知道了模块名并给出了必要的建议,这种方式会更加友好。

3. 解决方法

我能找到的在JavaScript中对命名导入启用自动完成的唯一解决方案是调用IDE以获得帮助。

例如,在Visual Studio Code中, 可以安装JavaScript (ES6) code snippets插件。

启用插件后,通过使用imd代码段并按tab键,光标首先跳到编写模块路径的位置。然后,在按下tab键后,光标会跳转回花括号内的导入位置。它是这样工作的:

你知道 JS 中的模块导入有一个缺点吗?

总结

在JavaScript中,导入语法会强制我们先指出要导入的项目(函数,类,变量),然后再指明模块的路径。这种方法不太友好。

相反,在Python中,首先指定模块名称,然后指定要导入的组件:from stringUtils import equalsIgnoreCase。使用此语法可以轻松自动完成导入的项目。

通过使用IDE的扩展插件,例如 ES6 code snippet 插件,可以减轻JavaScript中命名导入自动完成的问题, 总比没有好。

 

责任编辑:赵宁宁 来源: 大迁世界
相关推荐

2022-05-09 10:47:08

登录SpringSecurity

2020-08-29 19:15:09

python数据库SQLite

2022-09-29 15:32:58

云计算计算模式

2022-11-16 08:43:30

Node.js模块

2020-10-16 15:06:59

开发技术方案

2023-10-08 09:42:41

GitHubDataTable​Fill

2024-05-31 08:58:12

2021-11-02 22:50:10

鼠标计算机传感器

2024-04-09 11:40:58

DartJSWasmGC

2020-03-23 08:15:43

JavaScriptError对象函数

2010-11-19 09:16:38

2015-04-29 10:02:45

框架如何写框架框架步骤

2011-12-09 11:16:48

Node.js

2018-02-06 09:40:25

PythonOOP继承

2023-12-07 07:08:09

Angular函数

2022-06-29 08:32:04

游标MySQL服务器

2022-09-22 14:55:31

前端JavaScripthis

2022-09-26 13:10:17

JavaScriptthis

2021-08-22 15:02:51

Windows 10Windows微软

2023-04-26 10:21:04

点赞
收藏

51CTO技术栈公众号