0

0

JavaScript 模块

PHPz

PHPz

发布时间:2024-09-03 13:01:21

|

779人浏览过

|

来源于dev.to

转载

  • 现在我们不再将所有 js 写在一个文件中并发送给客户端。
  • 今天,我们将代码编写到模块中,这些模块之间共享数据并且更易于维护。
  • 约定是使用驼峰命名法命名模块。
  • 我们甚至可以通过 npm 存储库将第 3 方模块包含到我们自己的代码中,例如 jquery、react、webpack、babel 等。
  • 最终的捆绑包是由部署到产品服务器的小模块文件构建的,最终发送给客户端。
  • 旧版浏览器不支持模块
  • 出于性能原因,最好将小js文件发送到浏览器。
  • 模块是 js 中非常重要的一部分,开发人员已经在其他语言中使用了数十年。
  • 模块:可重用的一段代码,封装了项目某个部分的实现细节。
  • 它是一个独立文件,但不一定是。
  • 模块也可以有导入和导出 原生 es6 模块:es6 之前没有模块。必须自己实现或使用外部库。模块存储在文件中,每个文件只有一个模块。
  • 我们可以从模块中导出值、函数等。我们导出的任何内容都称为公共 api,公开供其他代码使用。
  • 这个公共 api 通过将公共代码导入到模块中来使用,称为依赖项。
  • 简单的应用程序也可以在没有模块的情况下编写,但是对于企业规模的项目,我们需要模块。
  • 高级:
    -> 使编写软件变得非常容易,因为模块是我们组合在一起构建复杂应用程序的小构建块。
    -> 隔离组件:每个功能都可以完全隔离地开发,无需担心其他开发人员的工作或整个系统的工作方式。
    -> 代码抽象:在模块中实现低级代码,将这些抽象导入到其他模块中,自然会导致更有组织的代码库。
    -> 代码可重用性:允许我们在多个项目中重用代码。

  • 现代 js 使用捆绑和转译。

## bundling = is a complex process which involves:
a. eliminate unused code
b. combine all modules into single file.
c. compress the code.
ex. webpack build tool - requires manual config, hence complex.
ex. parcel - zero build tool as we don't need to write any setup code.

## transpiling/polyfiling:
convert modern js to es5 or older syntax such that older browser supports the application. 
ex. done using tool called babel

entire process results in the final bundle file for production ready to be deployed on server. 
### scripts are also files but they are different from es6 modules in the following ways:
script[used earlier]:
- all top level variables are always global. this leads to global namespace pollution and name-coliision.
- default mode: sloppy mode
- top level 'this' points to window object.
- import/export of values is not allowed.
- linked to html using plain script tag.
- downloaded by default in sync way, unless async or defer attribute is used.

### es6 modules:
- all top-level variables are scoped to module i.e they are private by default. such a value can be access by outside varible only when its exported by the module else it will be inaccessible for outside world.
- default mode: strict mode. hence with modules no more need to declare strict mode.
- top level 'this' is 'undefined'
- allows import/export of values using es6 syntax of import/export.
- link to html file using 
                

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

151

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

396

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

504

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

187

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

120

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

176

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

39

2026.01.13

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

0

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号