首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS模块加载框架 SeaJS

SeaJS是一个遵循CMD规范的JavaScript模块加载框架,可以实现JavaScript的模块化开发及加载机制,兼容所有主流浏览器 SeaJS的主要目的是令JavaScript开发模块化并可以轻松愉悦进行加载...,让开发可以专注于代码本身的逻辑 上手示例 html中加载初始化模块init.js,init 中调用 module1 模块,同时 module1 模块调用 module2 模块 ?...,他有三个参数: 1)require 模块加载函数,用于记载依赖模块 2)exports 接口点,将数据或方法定义在其上则将其暴露给外部调用 3)module 模块的元数据,存储了模块的元信息(module.id...模块的ID、module.dependencies 此模块依赖的所有模块的ID列表、module.exports 与exports指向同一个对象) 模块的寻址 (1)绝对地址——给出js文件的绝对路径...require("http://example/js/a"); (2)相对地址——用载入函数所在js文件的相对地址寻找模块 例如有 js/a.jsjs/m/b.js 在b.js中调用上级级目录下的

6K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Node.js模块加载机制

    作者主页: 作者主页查看更多前端教学 专栏分享:css重难点教学 Node.js教学 从头开始学习 目录 模块加载机制         优先从缓存中加载          内置模块加载机制...require()不会导致模块的代码被执行多次。...定义一个模块,里面写好打印内容 console.log('打印并显示内容');  然后再另一个js文件中导入三次,看一看 会执行几次里面的内容。...内置模块加载机制 内置模块是由Node.js官方提供的模块,内置模块加载优先级最高。 意思是说  如果自定义模块,与内置模块同名,则优先会加载内置模块。        ...同时,在使用require()导入自定义模块时,如果省略了文件的扩展名,则Node 执行文件时会按顺序分别尝试加载以下的文件类领。

    1.2K20

    Node.js模块加载机制

    7、Node.js模块加载机制 (1)模块查找规则-当模块拥有路径但没有后缀时 image.png require方法根据模块路径查找模块,如果是完整路径,直接引入模块。...如果模块后缀省略,先找同名JS文件再找同名JS文件夹 如果找到了同名文件夹,找文件夹中的index.js 如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找main选项中的入口文件...如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到 (2)模块查找规则-当模块没有路径且没有后缀时 Node.js会假设它是系统模块 Node.js会去node_modules文件夹中...首先看是否有该名字的JS文件 再看是否有该名字的文件夹 如果是文件夹看里面是否有index.js 如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件 否则找不到报错...本机域名:localhost 本地IP :127.0.0.1 (2)创建web服务器 // 引用系统模块 const http = require('http'); // 创建web服务器

    1.8K20

    Node.js模块加载机制

    模块查找规则-当模块拥有路径但没有后缀时 require(' ./find.js') ; require(' ./find') ; require方法根据模块路径查找模块,如果是完整路径。...直接引入模块。...如果模块后缀省略,先找同名JS文件再找同名JS文件夹 如果找到了同名文件夹,找文件夹中的index.js 如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找...模块查找规则-当模块没有路径且没有后缀时 require(' find') ; Node.js会假设它是 系统模块 Node.js会去node_ modules文件夹中 首先看是否有该名字的...JS文件 再看是否有该名字的文件夹 如果是文件夹看里面是否有indexjs 如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件 否则找不到报错

    1.8K20

    Node.js模块加载机制

    1.模块查找规则-当模块拥有路径但没有后缀时 require(' ./find.js') ; require(' ./find') ; require方法根据模块路径查找模块,如果是完整路径。...如果模块后缀省略,先找同名JS文件再找同名JS文件夹 如果找到了同名文件夹,找文件夹中的index.js 如果文件夹中没有index.js就会去当前文件夹中的package.json文件中查找...main选项中的入口文件 如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到 2.模块查找规则-当模块没有路径且没有后缀时 require(' find') ; Node.js...会假设它是 系统模块 Node.js会去node_ modules文件夹中 首先看是否有该名字的JS文件 再看是否有该名字的文件夹 如果是文件夹看里面是否有indexjs...如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件 否则找不到报错

    1.3K30

    JS框架设计之加载器所在路径的探知一模块加载系统

    1、要加载一个模块,我们需要一个URL作为加载地址,一个script作为加载媒介,但用户在require是都用ID,我们需要一个将ID转换为URL的方法,思路很简单,强加个约定,URL的合成规则是为:...basepath+模块ID+".js" 2、当浏览器自上而下分析DOM,在浏览器解析我们的Javascript文件时(指的是加载器文件)时,他就肯定是DOM树最后一个加入的script标签,因此有下面的方法...执行不区分大小写的属性搜索,如果找到该属性,则返回内插值。 1 执行区分大小写的属性搜索。.../加载器/zcLoadJs.js">'); document.write('<script src="http://common.cnblogs.com/script/jquery.<em>js</em>...的路径 zcLoadJs为我的<em>加载</em>器,里面<em>执行</em>getBasePath()方法,预期得到zcLoadJs.<em>js</em>的服务器路径,但是在IE678中却返回juqery.<em>js</em>的路径,这个不奇怪,很多的常规方法在IE

    1K50

    重新审视前端模块的调用, 执行加载之间的关系

    因为模块必须先加载才能调用并执行, 模块加载器和构建工具就必须管理和分析应用中所有模块的依赖关系, 从而确定哪些模块可以拆分哪些可以合并, 以及模块加载顺序....不过这些努力依然没有超越先行模块化机制中的核心命题, 即模块必须先加载, 后调用执行. 只要这个核心命题不变, 模块的依赖问题依然是无解的....为此我们尝试提出了一种新的思路 模块为什么不能先调用, 后加载执行呢?...同时对于构建工具来说, 如果 A 模块执行并不基于 B 模块立即就绪这件事, 那么构建工具可以放心的将 A 和 B 模块拆成两个文件, 如果模块有很多, 就可以利用 http2 的并行加载能力, 大大提升模块加载性能...为了避免这个问题 模块构建工具需要分析两个文件的代码, 从而发现 localModule.js 依赖 remoteModule.js, 然后保存这个依赖顺序, 同时通知模块加载器, 为了让代码正常执行,

    55900

    深入Node.js模块加载机制,手写require函数

    执行找到的文件,同时要注入module和require这些方法和属性,以便模块文件使用。..._compile(content, filename); } 复制代码 可以看到js加载方法很简单,只是把文件内容读出来,然后调了另外一个实例方法_compile来执行他。..._compile是加载JS文件的核心所在,也是我们最常使用的方法,这个方法需要将目标文件拿出来执行一遍,执行之前需要将它整个代码包裹一层,以便注入exports, require, module, __...总结 require不是黑魔法,整个Node.js模块加载机制都是JS实现的。...为了解决循环引用,模块加载前就会被加入缓存,下次再加载会直接返回缓存,如果这时候模块还没加载完,你可能拿到未完成的exports。 Node.js实现的这套加载机制叫CommonJS。

    1.1K51

    结合源码分析 Node.js 模块加载与运行原理

    但是,对于 Node.js 模块化背后的加载与运行原理,我们是否清楚呢。首先抛出以下几个问题: Node.js 中的模块支持哪些文件类型? 核心模块和第三方模块加载运行流程有什么不同?...Node.js 模块类型 在 Node.js 中,模块主要可以分为以下几种类型: 核心模块:包含在 Node.js 源码中,被编译进 Node.js执行二进制文件 JavaScript 模块,也叫..._load 来加载执行 process.argv[1]。 下文我们在分析模块的 require 的时候,也会来到 lib/module.js 中,也会分析到 Module._load。...模块加载原理的关键:require 我们进一步,假设我们的 index.js 有如下内容: var http = require('http'); 那么当执行这一句代码的时候,会发生什么呢?...模块如何被编译进 Node.js执行文件: ?

    3.2K10

    Node.js学习笔记——模块加载机制及npm指令详解

    文章目录 二、模块化 1.模块化的基本概念 2.Node.js 中的模块化 Node.js模块的分类 加载模块 Node.js 中的模块作用域 向外共享模块作用域中的成员 Node.js 中的模块化规范...●注意:使用 require() 方法加载其它模块时,会执行加载模块中的代码 const fs = require('fs') // 内置模块 const custom = require...在终端中 执行 npm -v命令,来查看自己电脑上所安装的 npm 包管理工具的版本号 npm 安装 // dateFormat.js // 1....模块在第一次加载后会被缓存,多次调用 require() 模块的代码只会被执行一次。...●在使用 require() 导入自定义模块时,如果省略了文件的扩展名,Node.js 会按顺序分别尝试加载以下的文件 ​ 按照确切的文件名进行加载 ​ 补全 .js 扩展名进行加载 ​ 补全 .json

    1.1K20

    前端-结合源码分析 Node.js 模块加载与运行原理

    但是,对于 Node.js 模块化背后的加载与运行原理,我们是否清楚呢。首先抛出以下几个问题: 1、Node.js 中的模块支持哪些文件类型? 2、核心模块和第三方模块加载运行流程有什么不同?...Node.js 模块类型 在 Node.js 中,模块主要可以分为以下几种类型: 1、核心模块:包含在 Node.js 源码中,被编译进 Node.js执行二进制文件 JavaScript 模块,也叫..._load 来加载执行 process.argv[1]。 下文我们在分析模块的 require 的时候,也会来到 lib/module.js 中,也会分析到 Module._load。...模块加载原理的关键:require 我们进一步,假设我们的 index.js 有如下内容: var http = require('http'); 那么当执行这一句代码的时候,会发生什么呢?...模块如何被编译进 Node.js执行文件: ?

    2.2K20

    Python 重新加载模块

    简述 在进行模块化编程时,经常会遇到这样一种场景: 编写了一个 Python 模块,并用 import my_module 的形式进行导入。...模块仅被导入一次 出于效率原因(导入必须找到文件,将其编译成字节码,并且运行代码),Python shell 在每次会话中,只对每个模块导入一次。...>>> >>> import hello >>> import hello 可以看到,代码只执行了一次。也就是说,模块仅被导入了一次。...重新加载模块 倘若,更改了已经在 Python shell 中导入的模块,然后重新导入该模块,Python 会认为“我已经导入了该模块,不需要再次读取该文件”,所以更改将无效。...对于更复杂的情况,重新加载被编辑的模块也需要重新加载其依赖/导入的模块(因为它们必须作为被编辑模块初始化的一部分进行初始化),所以 IPython 的 autoreload 扩展很有用。

    4.4K10

    ABP - 模块加载机制

    前言 Abp是一个基于模块化开发的应用程序框架,提供了模块化基础的架构和模块加载的引擎。 理解模块 一个模块是对一个功能点的封装,可以独立成为一个包,实现了松耦合的代码组织方式。...模块之间可以引用,并且设置模块的依赖关系,一个模块加载时,会先加载其依赖的模块。...通过DependsOnAttribute可以指定模块依赖的模块,形成一个依赖链,Abp引擎启动时加载模块时,会先加载依赖模块。...应用程序引擎(容器)初始化时,通过应用程序引擎IAbpAppliaction,即AbpApplicationWithExternalServiceProvider,拿到各个模块信息(通过模块描述),执行各个模块中配置好的依赖注入...abp应用程序初始化过程图 以上,就是对Abp应用程序启动和模块加载机制的整理.

    30060
    领券