位置: 编程技术 - 正文

谈一谈JS消息机制和事件机制的理解(谈一谈js消息机制的理解)

编辑:rootadmin

推荐整理分享谈一谈JS消息机制和事件机制的理解(谈一谈js消息机制的理解),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:消息机制和事件机制,消息机制,消息机制,谈一谈js消息机制的理解,消息机制 java,消息机制,谈一谈js消息机制的理解,谈一谈js消息机制的理解,内容如对您有帮助,希望把文章链接给更多的朋友!

消息/事件机制是几乎所有开发语言都有的机制,并不是deviceone的独创,在某些语言称之为消息(Event),有些地方称之为(Message). 其实原理是类似的,只不过有些实现的方式要复杂一点。我们deviceone统一就叫消息.

消息基础概念

还有一些初学者不太熟悉这个机制,我们先简单介绍一些基础概念,如果熟悉的人可以跳过这个部分。一个/条消息可以理解为是一个数据结构,包含以下几个基本部分:

1.消息源:就是消息的来源,发出这个消息的对象

2.消息名:就是消息的唯一标示

3.消息数据:消息发出后附带的数据,有可能数据是空

消息从种类上又可以分为2种:

1.系统消息:由操作系统或deviceone系统发送出来的消息,消息的名称是固定的。

2.自定义消息:由开发者自己定义,自己发送出来的消息,消息的名字是随意的,可以任意定义。

举例说明:

比如用户点击一个do_Button按钮,就会触发一个系统消息,包含3个部分:

1.消息源:用户点中的button对象

2.消息名:touch

3.消息数据:这个消息没有附带数据

比如用户通过do_Button按钮触发一个自定义事件,包含3个部分:

1.消息源: button对象

2.消息名:用户随便定义,叫aaa,bbb,ccc都可以

3.消息数据:附带的数据由触发消息的时候设定

发布/订阅模式

发布/订阅模式是最常用的设计模式之一,是消息机制的核心,其特点就是降低耦合度,让二个独立的对象不互相依赖。简单介绍一下,熟悉的同学可以跳过。

我们先从现实的一个简单例子来说明这个问题,参考下图:

从这个图我们可以看出

1.消费者和出版社互相不认识,消费者不需要了解他想要的杂志是具体哪家出版社出的;出版社也不需要了解具体是哪个人定了他们出版社发行的书。

2.消费者和出版社必须都认识邮局。

3.消费者需要告诉邮局消费者的名字地址以及想要订阅的杂志名字

4.可以多个消费者订阅同一本杂志

谈一谈JS消息机制和事件机制的理解(谈一谈js消息机制的理解)

5.邮局拿到杂志后,会一一通知消费者,通知的时候同时把杂志送到消费者手里。

看完上面现实例子,我们再来看抽象的描述会更清晰一点,看下图:

和上面的实际例子描述一一对应:

1.系统/开发者和函数对象互相不依赖,系统/开发者只管触发一个消息,并不关心谁去接受

2.系统/开发者和函数对象必须能获取到消息源对象

3.函数对象订阅消息的时候需要标示消息的名称和函数对象的引用

4.可以多个函数对象订阅同一个消息源同一名字的消息

5.消息源触发消息会一一通知所有订阅者,并把data数据传递到回调函数对象

看完抽象的描述,我们最后来看实际的deviceone开发的例子,还是以do_Button为例子。

1. 当用户点击一个button,触摸到的时候,系统会获取到button这个对象作为消息源,fire一个”touch”消息,任何订阅了”touch”消息的函数对象都会接收到这个消息并引起函数的执行。

2. 我们可以为button对象定义2个自定义的消息”message1”和”message2”,分别有2个函数对象订阅这2个消息。但是最后要触发这个消息必须是开发者通过调用fire函数才能触发,这就是和系统消息的区别。

看到这里,你肯定会奇怪,为什么我们要在button上自定义对象?这有神马意义?其实确实没有意义也没有必要,这里只是拿button举例子,在常规的开发中,基本不会这么用。

消息的使用

前面讲了这么多,现在才是deviceone消息的使用。使用其实很简单,上面的例子基本说明的了系统事件和自定义事件的使用方法。

有几个概念再说明一下

1.deviceone的所有对象,包括UI,MM,SM对象都可以是消息源

2.消息源对象有作用域,所以订阅和触发的消息源必须是是一个作用域的同一个对象。这里结合数据分享和数据传递文档来理解。

看以下的例子,test1.ui和test2.ui有可能在一个page作用域,也有可能不在一个作业域,只有在一个作用域fire的消息才能正确送达回调函数。

判断是否一样,可以通过打印page的地址 page.getAddress().

如果不在同一page作用域,则可以把消息订阅在2个page都能共享到的app作用域上面的代码改成:

3.同样的函数对象可以重复订阅一个对象源的消息,触发消息的时候会使函数执行多次,这是初学者经常犯的错误。

看上面的例子,如果执行的话,会打印2此,因为订阅了2次,或许你会说谁会写这样的代码?实际情况肯定没有这么容易看出来执行了重复的on函数,实际情况经常是比如在点击事件里执行on函数,每点击一下按钮,就重复订阅一次。

4.消息的订阅一定要在消息的触发之前,这是初学者经常犯的错误。

看上面的例子,如果执行的话,会没有效果,或许你会说谁会写这样的代码?实际情况肯定没有这么容易看出来顺序反了,实际情况经常是比如on函数执行在某一个函数的回调函数里,你无法确定回调函数啥时候执行,是否是在fire之前执行。一般碰到这种情况可以加几个deviceone.print打印一下看看是on先执行还是fire先执行。

5.有订阅就有取消订阅,取消订阅是off函数,之所以很少用,是因为closePage的时候会自动把当前page作用域订阅的消息全部释放。

但是如果消息订阅在app作用域,就要注意,可能需要手动去取消订阅。否则就会出现触发消息的时候会使函数执行多次的问题。

看上面的例子,打印只会执行一次,因为fire一次后就取消订阅了。

Javascript实现鼠标框选操作 不是点击选取 本文实例为大家分享了Javascript实现鼠标框选操作,绝不是点击选取,供大家参考,具体内容如下效果图:代码:htmlhead/headstylebody{padding:px;}.fileDiv{float

js仿小游戏选字游戏 本文实例为大家分享了js仿小游戏中你是色盲吗游戏,大家先来挑战一下游戏目标:按画面中出现的文字的颜色来选择颜色,千万不要被颜色的困局打

原生js实现autocomplete插件 在实际的项目中,能用别人写好的插件实现相关功能是最好不过,为了节约时间成本,因为有的项目比较紧急,没充分时间让你自己来写,即便写了,

标签: 谈一谈js消息机制的理解

本文链接地址:https://www.jiuchutong.com/biancheng/373445.html 转载请保留说明!

上一篇:Kindeditor在线文本编辑器如何过滤HTML(kindeditor获取内容)

下一篇:Javascript实现鼠标框选操作 不是点击选取(js实现鼠标事件)

  • 房屋租赁如何开增值税专用发票
  • 工程预付款的支付要求
  • 应交税费和税金及附加的关系
  • 进口原料免税
  • 职工食堂费用计入管理费用
  • 平台收取的佣金开具什么发票
  • 叉车折旧年限是几年预计净残值
  • 物流托运不给发货怎么办
  • 企业转让固定资产要交什么税
  • 小规模季超30万,蔬菜还免增值税吗
  • 医疗服务收入占比标准
  • 通用机打发票能作废吗
  • 接受投资的固定资产账务处理
  • 营改增后电力行业非正常损失怎么做会计处理?
  • 其他货币资金是资产类科目吗
  • 购入材料用什么科目
  • 提取法定盈余公积比例
  • 贴标企业
  • 工业企业购买电机会计分录
  • 小规模建筑业有增值税吗
  • 营业外收入是否报增值税
  • 跨年度取得增值税发票能否抵扣?
  • 金税三期收回长期投资所得税如何申报?
  • 异地交纳的五险一金可以在个人所得税扣除吗?
  • 股东与公司之间是什么关系
  • 房地产企业已预缴增值税如何抵扣
  • 老板垫付的钱应该怎么做科目
  • 如何升级mac系统到10.12
  • 餐饮企业原材料的核算,新城饭店为增值税一般纳税人
  • 收到负数发票怎么办
  • 辞职的补偿金怎么做账
  • 合伙企业取得红利怎么交税
  • icon files
  • 代办退税账务处理
  • 高薪技术企业研发费用标准
  • 委托加工物资企业收回自用
  • 默认网关不可用的解决办法
  • 其他应付款结转什么科目
  • 前端如何用canvas绘制座位图
  • php生成php文件
  • 主播录屏软件哪个好
  • 大沼泽地国家公园位于哪个城市
  • 季度缴纳企业所得税计算方法
  • 融资租入的办公楼
  • vue3.0配置
  • php提供的三种在函数内使用全局变量的方式
  • php中自定义函数的语法格式
  • 帝国cms对接小程序
  • 将外购商品用于个人消费
  • 微信收款怎么记录怎么删除
  • 小程序集合软件
  • 公对私转账没有到账怎么查询
  • 差额冲账法
  • 软件企业该怎么发展起来
  • 数据库生成随机数函数
  • 党费会计核算科目有哪些
  • mysql insert语句操作实例讲解
  • 销售折扣购物卡对公司财务的好处
  • 材料成本差异的会计分录
  • 企业年底亏损怎么结转
  • 银行承兑汇票向银行申请贴现会计分录
  • 生产成本直接人工怎么算
  • win7系统如何安装蓝牙驱动
  • win8操作系统如何安装
  • win10系统wifi信号断断续续
  • win10系统声音忽大忽小
  • cocos2dx scrollview
  • opengl 输入框
  • javascriptdom编程
  • jquery可以实现哪些效果
  • html竖排改为横排
  • cmd替换文件命令
  • unity中ngui
  • js判断用户输入密码
  • Android SQLite, KopDB 框架学习1——使用
  • 外经证预缴税款网上流程
  • 担保费属于什么服务
  • 四川国税网上申报大厅
  • 园区地税局在哪里
  • 延安市地方税务局电话
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设