layui源码详细分析系列之element模块以及自定义事件机制

element内置模块时layui框架中页面元素的交互功能的实现,主要是选项卡、面板、导航等的交互的实现。

下面先分析element模块的组织结构,具体如下图所示:
element模块组织结构

从上图中可以看出,element模块使用该框架自己的模块加载机制来加载该模块。

该框架内置的模块都是采用面向对象的编程,该模块也是,定义了Element构造函数,对外的API接口都定义在Element的原型对象上,使用JQuery来绑定一些原生的事件。call对象中定义真正处理选项卡等交互以及初始状态的处理程序。

element模块中使用框架自己定义的事件处理机制,具体实际上使用layui主体文件中的onevent和event来进行事件的注册以及事件的执行。

因为该模块最后输出的是函数类型,所以在使用该模块时要求如下:

layui.use(['element'], function() {
	var element = layui.element();
});

上面实际会自动执行一些初始化的工作,具体就会选项卡、面板等的初始状态的设置。

下面讲解layui自定义的事件机制,该框架定义事件名的形式如下:

功能名(lay-filter属性名)

在该框架中有lay-filter属性,该属性就是用于事件标识的。

什么时候使用该框架内置的事件机制?当你想要执行其他的操作,例如获取相关数据等,就可以使用自定义的事件机制。

下面使用实例来讲解框架事件机制的具体的逻辑处理,假设选项卡有属性lay-filter=‘demo’, 那么就可以使用该框架自定义的事件机制,具体如下:

使用该机制的代码:
layui.use(['element'], function() {
	var ele = layui.element();
	
	// tab(demo)就是事件名
	ele.on('tab(demo)', function(data) {
		cosnole.log(data);
	});
});

具体的逻辑流程如下图:
layui自定义事件机制

具体如上图所示,实际上内部维持了config.event对象来保存事件,onevent实现事件注册以及监听,实际上就是存储在config.event对象中,具体存储形式如下:

config.event[modeName + '.' + event] = [callback]

在本例中modeName为element,event为tab(demo), callback就是就是事件处理程序,本例中callback如下:

callback = functio(data) {
	console.log(data);
};

详细的代码注释以及相关的逻辑图我会上传到我的Github上,通过今天对于现在这种代码学习,有些迷茫了。

总结下现在这种阅读代码的方式的缺点:

  1. 有点纸上谈兵的感觉,不充实很虚
  2. 有些为看而看的感觉,没有非常大的收获,反而有些疲惫,没有自己成长了的自豪感

所以以后的文章就不会是这种方式出现了,目前想到的很好提高自己同时最大程度的提高自己,以后的风格将会以事实为依据,来具体展开,具体的形式如下:

  1. 自己会动手编写一个简易版实现核心功能的demo,并给出自己的思路
  2. 查看框架作者实现的思路,比较自己的思路与作者思路的相同点以及不同点,进行分析总结,丰满自己的思路

今天就到此为止,走走停停,方能走得更远,明天会分析文件上传以及流加载模块。

致远行的你我
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在对Node-RED源代码中的editor-api模块进行分析前,我们需要了解Node-RED是一个基于Node.js的流程编程工具,通过编写流程来实现不同设备之间的连接和通讯。editor-api模块是Node-RED的一个子模块,负责提供与流程编辑器相关的API接口。 首先,editor-api模块的代码位于Node-RED的`red/runtime/editor-api.js`文件中。该模块主要提供了一些用于流程编辑器的API接口,包括获取和更新流程信息、节点信息、连接信息等等。 在代码中,首先定义了一个`EditorAPI`类,该类通过`RED`对象的`comms`模块来工作。`comms`模块用于处理流程编辑器的通信和发送消息。 接着,在`EditorAPI`类中定义了一系列的方法,用来对流程、节点和连接等信息进行操作。其中一些重要的方法包括: - `getFlows`:用于获取当前所有流程的信息。 - `getFlow`:根据流程ID获取特定流程的信息。 - `getFlowTab`:根据流程ID获取对应的流程tab,用于在编辑器中显示和操作流程。 - `updateFlow`:用于更新特定流程的信息。 - `getNode`:根据节点ID获取节点的信息。 - `addNode`:用于在流程中添加新的节点。 - `getConnections`:获取当前所有节点的连接信息。 通过这些方法,开发者可以方便地对流程进行增加、删除、修改等操作,并在编辑器中进行实时的反馈。 此外,还有一些与编辑器的交互相关的方法,比如`selectTab`方法用于切换当前编辑的流程tab,`resize`方法用于调整编辑器的大小等。 总的来说,editor-api模块的代码分析主要围绕着提供与流程编辑器相关的API接口展开,给开发者提供了一种方便灵活的方式来操作和管理流程及其相关信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值