CN111897694B - 小程序中消息处理方法及装置、设备、存储介质 - Google Patents
小程序中消息处理方法及装置、设备、存储介质 Download PDFInfo
- Publication number
- CN111897694B CN111897694B CN202010753540.2A CN202010753540A CN111897694B CN 111897694 B CN111897694 B CN 111897694B CN 202010753540 A CN202010753540 A CN 202010753540A CN 111897694 B CN111897694 B CN 111897694B
- Authority
- CN
- China
- Prior art keywords
- monitoring
- functional component
- event
- data change
- component
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 40
- 238000012545 processing Methods 0.000 title claims abstract description 18
- 238000012544 monitoring process Methods 0.000 claims abstract description 181
- 230000008859 change Effects 0.000 claims abstract description 84
- 230000006870 function Effects 0.000 claims description 50
- 230000015654 memory Effects 0.000 claims description 19
- 238000013507 mapping Methods 0.000 claims description 8
- 230000008569 process Effects 0.000 claims description 8
- 238000001514 detection method Methods 0.000 claims description 6
- 238000010586 diagram Methods 0.000 description 12
- 238000007726 management method Methods 0.000 description 12
- 238000011161 development Methods 0.000 description 9
- 238000004590 computer program Methods 0.000 description 7
- 238000003672 processing method Methods 0.000 description 6
- 238000013461 design Methods 0.000 description 5
- 230000004044 response Effects 0.000 description 5
- 238000004891 communication Methods 0.000 description 4
- 238000012423 maintenance Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 4
- 238000013501 data transformation Methods 0.000 description 3
- 230000007246 mechanism Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 230000006399 behavior Effects 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 230000000739 chaotic effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000002054 transplantation Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
- 239000002699 waste material Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3051—Monitoring arrangements for monitoring the configuration of the computing system or of the computing system component, e.g. monitoring the presence of processing resources, peripherals, I/O links, software programs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/445—Program loading or initiating
- G06F9/44521—Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
- G06F9/44526—Plug-ins; Add-ons
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Software Systems (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- Mathematical Physics (AREA)
- Stored Programmes (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请公开了小程序中消息处理方法及装置、设备、存储介质,涉及小程序领域。具体实现方案为:基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事情;确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以使所述第一功能组件获取到所述通知消息后能够基于所述第二功能组件的数据变化事件进行数据处理。如此,解决了现有功能组件无法快速并及时获知所关注的数据实体的变化问题。
Description
技术领域
本申请涉及数据处理领域,尤其涉及小程序领域。本申请可应用于自动驾驶领域,尤其是自主泊车领域。
背景技术
随着小程序业务需求复杂度的提升,小程序内部业务模块(也即功能组件)设计越发庞大,各个业务模块之间的逻辑关联也越发复杂。而且,在实际设计中,经常存在如下情况,即多个业务模块使用同一个业务数据实体,并且需要实时关注该业务数据实体的改动情况,如此,来做出相应的更新操作。因此,如何能够使得各业务模块快速并及时获取到所关注业务数据实体的改动情况,成为亟待解决的问题。
发明内容
本申请提供了一种小程序中消息处理方法及装置、设备、存储介质。
根据本申请的一方面,提供了一种小程序中消息处理方法,包括:
基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事件;
确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理。
根据本申请的另一方面,提供了一种小程序中消息处理装置,包括:
监听单元,用于基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事件;
发布单元,用于确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理。
根据本申请的再一方面,提供了一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行以上所述的方法。
根据本申请的再一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行以上所述的方法。
根据本申请的再一方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现如上所述的方法。
根据本申请的技术解决了现有功能组件无法快速并及时获知所关注的数据实体的变化问题,提升了小程序中各功能组件的响应效率。
应当理解,本部分所描述的内容并非旨在标识本申请的实施例的关键或重要特征,也不用于限制本申请的范围。本申请的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本申请的限定。其中:
图1是根据本申请第一实施例的示意图;
图2是根据本申请第二实施例的示意图;
图3是根据本申请第三实施例的示意图一;
图4是根据本申请第三实施例的示意图二;
图5是根据本申请第三实施例的示意图三;
图6是根据本申请第三实施例的示意图四;
图7是根据本申请第四实施例的示意图;
图8是根据本申请实施例小程序中消息处理装置的结构示意图一;
图9是根据本申请实施例小程序中消息处理装置的结构示意图二;
图10是根据本申请实施例小程序中消息处理装置的结构示意图三;
图11是用来实现本申请实施例的小程序中消息处理方法的电子设备的框图。
具体实施方式
以下结合附图对本申请的示范性实施例做出说明,其中包括本申请实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本申请的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
本申请方案提供一种小程序中消息处理方法,如图1所示,包括:
步骤S101:基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事件。
步骤S102:确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理。
这样,解决了现有功能组件无法快速并及时获知所关注的数据实体的变化问题,提升了小程序中各功能组件的响应效率。
而且,由于能够利用监听事件来对各功能组件的数据变换事件进行监听,所以为实现小程序中监听消息的统一管理奠定了基础;又由于本申请方案无需依赖其他业务模块而实现,简单方便,所以,为提升小程序的开发效率,降低开发成本也奠定了基础。
本申请方案中,所述第一功能组件为监听功能组件,所述第二功能组件为被监听功能组件。
在本申请方案的一具体示例中,如图2所示,步骤S102包括:
步骤S102-1:获取监听列表,其中,所述监听列表至少表征注册监听事件的监听功能组件与被监听功能组件之间的映射关系,所述监听列表基于所述小程序中监听功能组件的开启状态而动态变化,以至少确保所述监听列表中各监听功能组件处于开启状态。
步骤S102-2:确定所述监听列表中的监听功能组件包含有所述第一功能组件。也就是说,确定所述监听列表中存在有所述第一功能组件后,认为所述第一功能组件处于开启状态,以便于所述第一功能组件能够接收到所述监听消息。
步骤S102-3:发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理。
这样,由于建立有能够基于监听功能组件的运行状态,也即是否处于开启状态来动态更新的所述监听列表,所以,能够有效提升发布的所述监听消息的触发率,进而,能够在有效避免资源浪费的基础上,确保监听功能组件快速并及时获知所关注的数据实体的变化情况,提升了小程序中监听功能组件的响应效率。
在本申请方案的一具体示例中,在步骤S101之前,还包括:
获取监听请求信息,其中,所述监听请求信息指示所述第一功能组件请求注册对所述第二功能组件的数据变化事件进行监听的监听事件;
基于所述监听请求信息,确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
如此,实现监听事件的注册机制,使得监听事件能够基于监听功能组价的需求而设置,为小程序中各功能组件提供了监听事件的定制化服务,进而为有效提升小程序的开发效率奠定了基础。
在本申请方案的一具体示例中,当第一功能组件发起监听请求信息后,此时,有效复用已生成的监听事件,避免重复生成监听事件,还可以基于所述监听请求信息,来检测是否存在针对所述第二功能组件的监听事件,基于检测结果确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
比如,若基于检测结果确定存在针对所述第二功能组件的监听事件,比如,存在其他功能组件注册的针对所述第二功能组件的监听事件,此时,可以直接基于存在的针对所述第二功能组件的监听事件对第二功能组件的数据变化事情进行监听,而无需重新建立新的监听事件。否则,若基于检测结果确定不存在针对所述第二功能组件的监听事件,则生成针对所述第二功能组件的监听事件,进而基于新生成的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
在本申请方案的一具体示例中,当第一功能组件发起监听请求信息后,可以采用如下两种方式来确定针对所述第二功能组件的监听事件,具体地,
方式一:基于所述监听请求信息,生成针对所述第二功能组件的监听事件,以基于生成的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听;也就是说,直接生成针对所述第二功能组件的监听事件,进而基于新生成的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
方式二:基于所述监听请求信息,获取历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件,以基于历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。也就是说,存在其他功能组件注册的针对所述第二功能组件的监听事件,此时,可以直接基于已生成的针对所述第二功能组件的监听事件对第二功能组件的数据变化事情进行监听,而无需重新建立新的监听事件。
这里,需要说明的是,实际应用中,以上两种方式可以基于需求而灵活使用,比如,当存在其他功能组件注册的针对所述第二功能组件的监听事件,此时,可以基于所述监听请求信息,生成新的针对所述第二功能组件的监听事件,还可以不生成新的监听事件,而是直接复用已生成的针对所述第二功能组件的监听事件对第二功能组件的数据变化事情进行监听。
实际应用中,还会基于监听事件的注册情况来建立监听列表,并基于监听功能组件的运行状态,以及监听事件的变化情况来维护所述监听列表。这里,所述监听列表中记录有监听事件,以及监听事件所对应的监听功能组件与被监听功能组件之间的映射关系,可以为一对一关系,也可以为一对多关系,本申请方案对此不作限制,只要能够有效描述监听事件对应的监听功能组件和被监听功能组件之间的映射关系即可。
在本申请方案的一具体示例中,为避免无效监听事件浪费计算资源,本申请方案还可以根据监听功能组件对监听事件的监听需求来注销监听事件,具体地,
获取监听注销信息,其中,所述监听注销信息指示所述第一功能组件注销对所述第二功能组件的数据变化事件的监听事件;
基于所述监听注销信息注销所述第一功能组件所注册的针对所述第二功能组件的数据变化事件的监听事件,或者,注销针对所述第二功能组件的数据变化事件的监听事件。
也就是说,实际注销过程中,可仅注销所述第一功能组件所注册的针对所述第二功能组件的监听事件,比如,仅将监听列表中第一功能组件与第二功能组件之间的监听关联关系注销掉,此时,所述监听列表中可能还会记录有其他功能组件所注册的针对第二功能组件之间的监听事件。或者,还可以直接将整个针对第二功能组件的数据变化事件的监听事件注销掉,即在所述监听列表中将针对所述第二功能组件的数据变化事件的监听事件全部注销掉,此时,所述监听列表中不再记录有针对第二功能组件的数据变化事件的监听事件。
这样,解决了现有功能组件无法快速并及时获知所关注的数据实体的变化问题,提升了小程序中各功能组件的响应效率。而且,由于能够利用监听事件来对各功能组件的数据变换事件进行监听,所以为实现小程序中监听消息的统一管理奠定了基础;又由于本申请方案无需依赖其他业务模块而实现,简单方便,所以,为提升小程序的开发效率,降低开发成本也奠定了基础。
以下结合具体示例对本申请方案做进一步详细说明,具体地,本申请方案能够统一管理全局数据,并统一管理全局数据变动带来的消息分发工作。具体地,在整个小程序运行环境内,能够灵活创建指定数据频道(也即被监听功能组件)的监听器,这里,一个监听事件可以对应一个监听器。如此,通过监听器即可使监听功能模块接收数据变动的通知消息,以及使被监听功能模块发布指定数据频道的变更消息,这里的通知消息和变更消息均为监听消息,实际应用中,会将该监听消息分发至小程序运行环境内的所有监听器,以便于监听功能组件能够及时获知到所需监听的数据实体的变动情况。
具体地,如图3所示,,全局消息分发模块内部设计包括三部分功能,分别为:注册监听事件,注销监听事件,以及针对监听事件的监听消息分发。其中,每个监听事件可以具体对应一个监听列表,该监听列表记录有监听功能组件与被监听功能组建之间的映射关系,当然,实际应用中,监听列表中还可以记录有监听功能模块所需具体监听的数据实体的详情,本申请方案对此不作限制。
当然,为了便于列表的维护,不同的监听事件可以对应一个总的监听列表,如此,通过总的监听列表来对监听事件进行统一管理。
进一步地,如图4和图5所示,本申请方案给出监听器创建和移除逻辑设计,具体地,如图4所示,注册监听事件,判断监听事件是否存在,若存在,直接复用已有监听事件,否则创建监听事件。如图5所示,注销监听事件,判断监听事件是否复用,若是,从监听列表中注销本次注销事件对应的监听功能组件的监听事件,即从监听列表中删除掉(也即注销掉)本次注销事件所对应的监听功能组件与被监听功能组件之间的映射关系;否则,注销整个监听事件。
进一步地,如图6所示,监听消息分发逻辑设计,检测到监听消息,判断监听列表中是否存在有该监听消息所对应的监听功能组件,若存在,发布该监听消息,否则,返回,继续检测是否存在监听消息。
以下结合小程序音乐播放器的播放状态维护和变更事件分发来对本申请方案进行说明,如图7所示,该音乐播放器具有全局音频播放管理功能,即不同的功能界面,比如,首页、专辑详情页面、音频播放界面、个人中心页面等均能对音频播放进行控制;而且,该多个功能界面均需要对播放状态进行监控,以便于及时进行更新展示。
基于此,本示例以播放状态(如播放或暂停)维护涉及的消息分发举例,来描述本申请方案在小程序产品中的应用。具体地,如图7所示,小程序音乐播放器的全局音频播放管理类中封装全局消息分发模块,该全局消息分发模块用于统一注册监听器,以及发送表征状态变更事件的监听消息;图7所示的各功能界面注册有监听器,该监听器用于监听播放器的播放状态(播放中,暂停中),而全局播放管理类用于代理监听器(播放状态变更监听器)的注册行为,即代理各功能界面向全局消息分发模块进行监听器注册;另外,全局播放管理类会统一控制播放器的播放状态,各个功能界面对于播放状态的操作均通过调用全局播放管理类的API来完成,而当全局播放管理类检测到播放状态存在变化后,会发送一个状态变化的信息到全局消息分发模块,使全局消息分发模块将该信息分发至所有消息监听者,也即各功能界面,如此,来完成消息分发及监听流程。
这里,需要说明的是,本示例需要基于以下核心技术实现:
JavaScript运行环境:基于JavaScript编程语言编写的基础机制功能模块,需要在JavaScript环境中才能使用。
Node.js运行环境或小程序运行环境(如百度小程序运行环境,或微信小程序运行环境)。
这样,将业务项目中可能遇到的各种繁杂的数据引用和消息分发需求,抽象为一个统一的分发机制来管理,降低了消息分发等复杂逻辑在业务模块中的开发量;而且,该方案可即插即用,不依赖过多模块类库,使用简单方便,所以,可极大提升开发效率。
而且,相比于现有将全局数据存储于能够被全局访问的存储设备,各业务模块按需读取的方式相比,本申请方案还降低了代理逻辑的维护成本,解决了现有方式混乱不便于管理的问题,同时,能够有效避免出现脏数据;还具有便于功能移植,可复用性强的优势。
本申请方案还提供一种小程序中消息处理装置,如图8所示,包括:
监听单元801,用于基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事件;
发布单元802,用于确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理。
在本申请方案的一具体示例中,所述发布单元802,还包括:
列表获取子单元,用于获取监听列表,其中,所述监听列表至少表征注册监听事件的监听功能组件与被监听功能组件之间的映射关系,所述监听列表基于所述小程序中监听功能组件的开启状态而动态变化,以至少确保所述监听列表中各监听功能组件处于开启状态;
组价确定子单元,用于确定所述监听列表中的监听功能组件包含有所述第一功能组件。
在本申请方案的一具体示例中,如图9所示,还包括:
监听请求信息获取单元803,用于获取监听请求信息,其中,所述监听请求信息指示所述第一功能组件请求注册对所述第二功能组件的数据变化事件进行监听的监听事件;
监听事件确定单元804,用于基于所述监听请求信息,确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
在本申请方案的一具体示例中,所述监听事件确定单元,还用于:
检测是否存在针对所述第二功能组件的监听事件,基于检测结果确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
在本申请方案的一具体示例中,所述监听事件确定单元,还用于:
生成针对所述第二功能组件的监听事件,以基于生成的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听;或者,
获取历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件,以基于历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
在本申请方案的一具体示例中,如图10所示,还包括:
监听注销信息获取单元805,用于获取监听注销信息,其中,所述监听注销信息指示所述第一功能组件注销对所述第二功能组件的数据变化事件的监听事件;
监听事件注销单元806,用于基于所述监听注销信息注销所述第一功能组件所注册的针对所述第二功能组件的数据变化事件的监听事件,或者,注销针对所述第二功能组件的数据变化事件的监听事件。
根据本申请的实施例,本申请还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
如图11所示,是根据本申请实施例的小程序中消息处理方法的电子设备的框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本申请的实现。
如图11所示,该电子设备包括:一个或多个处理器1101、存储器1102,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在电子设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示GUI的图形信息的指令。在其它实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个电子设备,各个设备提供部分必要的操作(例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统)。图11中以一个处理器1101为例。
存储器1102即为本申请所提供的非瞬时计算机可读存储介质。其中,所述存储器存储有可由至少一个处理器执行的指令,以使所述至少一个处理器执行本申请所提供的小程序中消息处理方法。本申请的非瞬时计算机可读存储介质存储计算机指令,该计算机指令用于使计算机执行本申请所提供的小程序中消息处理方法。
存储器1102作为一种非瞬时计算机可读存储介质,可用于存储非瞬时软件程序、非瞬时计算机可执行程序以及模块,如本申请实施例中的小程序中消息处理方法对应的程序指令/模块(例如,附图10所示监听单元801、发布单元802、监听请求信息获取单元803、监听事件确定单元804、监听注销信息获取单元805和监听事件注销单元806)。处理器1101通过运行存储在存储器1102中的非瞬时软件程序、指令以及模块,从而执行服务器的各种功能应用以及数据处理,即实现上述方法实施例中的小程序中消息处理方法。
存储器1102可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据小程序中消息处理方法的电子设备的使用所创建的数据等。此外,存储器1102可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些实施例中,存储器1102可选包括相对于处理器1101远程设置的存储器,这些远程存储器可以通过网络连接至小程序中消息处理方法的电子设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
小程序中消息处理方法的电子设备还可以包括:输入装置1103和输出装置1104。处理器1101、存储器1102、输入装置1103和输出装置1104可以通过总线或者其他方式连接,图11中以通过总线连接为例。
输入装置1103可接收输入的数字或字符信息,以及产生与小程序中消息处理方法的电子设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等输入装置。输出装置1104可以包括显示设备、辅助照明装置(例如,LED)和触觉反馈装置(例如,振动电机)等。该显示设备可以包括但不限于,液晶显示器(LCD)、发光二极管(LED)显示器和等离子体显示器。在一些实施方式中,显示设备可以是触摸屏。
此处描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、专用ASIC(专用集成电路)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
这些计算程序(也称作程序、软件、软件应用、或者代码)包括可编程处理器的机器指令,并且可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。如本文使用的,术语“机器可读介质”和“计算机可读介质”指的是用于将机器指令和/或数据提供给可编程处理器的任何计算机程序产品、设备、和/或装置(例如,磁盘、光盘、存储器、可编程逻辑装置(PLD)),包括,接收作为机器可读信号的机器指令的机器可读介质。术语“机器可读信号”指的是用于将机器指令和/或数据提供给可编程处理器的任何信号。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与虚拟专用服务器(VPS)服务中,存在的管理难度大,业务扩展性弱的缺陷。
根据本申请实施例的技术方案,解决了现有功能组件无法快速并及时获知所关注的数据实体的变化问题,提升了小程序中各功能组件的响应效率。而且,由于能够利用监听事件来对各功能组件的数据变换事件进行监听,所以为实现小程序中监听消息的统一管理奠定了基础;又由于本申请方案无需依赖其他业务模块而实现,简单方便,所以,为提升小程序的开发效率,降低开发成本也奠定了基础。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发申请中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本申请公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本申请保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本申请的精神和原则之内所作的修改、等同替换和改进等,均应包含在本申请保护范围之内。
Claims (8)
1.一种小程序中消息处理方法,包括:
基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事件;
确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理;
所述确定所述第一功能组件处于开启状态,包括:
获取监听列表,其中,所述监听列表至少表征注册监听事件的监听功能组件与被监听功能组件之间的映射关系,所述监听列表基于所述小程序中监听功能组件的开启状态而动态变化,以至少确保所述监听列表中各监听功能组件处于开启状态;
确定所述监听列表中的监听功能组件包含有所述第一功能组件;
所述方法,还包括:
获取监听请求信息,其中,所述监听请求信息指示所述第一功能组件请求注册对所述第二功能组件的数据变化事件进行监听的监听事件;
基于所述监听请求信息,确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听;
所述方法,还包括:
获取监听注销信息,其中,所述监听注销信息指示所述第一功能组件注销对所述第二功能组件的数据变化事件的监听事件;
基于所述监听注销信息注销所述第一功能组件所注册的针对所述第二功能组件的数据变化事件的监听事件,或者,注销针对所述第二功能组件的数据变化事件的监听事件。
2.根据权利要求1所述的方法,其中,所述确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听,包括:
检测是否存在针对所述第二功能组件的监听事件,基于检测结果确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
3.根据权利要求1或2所述的方法,其中,所述确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听,包括:
生成针对所述第二功能组件的监听事件,以基于生成的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听;或者,
获取历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件,以基于历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
4.一种小程序中消息处理装置,包括:
监听单元,用于基于监听事件,监听到第二功能组件的数据变化事件,其中,所述监听事件是小程序中第一功能组件所注册的用于对小程序中所述第二功能组件的数据变化事件进行监听的事件;
发布单元,用于确定所述第一功能组件处于开启状态后,发布表征所述第二功能组件的数据变化事件对应的监听消息,以便所述第一功能组件获取到所述监听消息后基于所述第二功能组件的数据变化事件进行数据处理;
所述发布单元,还包括:
列表获取子单元,用于获取监听列表,其中,所述监听列表至少表征注册监听事件的监听功能组件与被监听功能组件之间的映射关系,所述监听列表基于所述小程序中监听功能组件的开启状态而动态变化,以至少确保所述监听列表中各监听功能组件处于开启状态;
组件确定子单元,用于确定所述监听列表中的监听功能组件包含有所述第一功能组件;
所述装置,还包括:
监听请求信息获取单元,用于获取监听请求信息,其中,所述监听请求信息指示所述第一功能组件请求注册对所述第二功能组件的数据变化事件进行监听的监听事件;
监听事件确定单元,用于基于所述监听请求信息,确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听;
所述装置,还包括:
监听注销信息获取单元,用于获取监听注销信息,其中,所述监听注销信息指示所述第一功能组件注销对所述第二功能组件的数据变化事件的监听事件;
监听事件注销单元,用于基于所述监听注销信息注销所述第一功能组件所注册的针对所述第二功能组件的数据变化事件的监听事件,或者,注销针对所述第二功能组件的数据变化事件的监听事件。
5.根据权利要求4所述的装置,其中,所述监听事件确定单元,还用于:
检测是否存在针对所述第二功能组件的监听事件,基于检测结果确定针对所述第二功能组件的监听事件,以基于针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
6.根据权利要求4或5所述的装置,其中,所述监听事件确定单元,还用于:
生成针对所述第二功能组件的监听事件,以基于生成的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听;或者,
获取历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件,以基于历史生成的其他功能组件所注册的针对所述第二功能组件的监听事件对所述第二功能组件的数据变化事情进行监听。
7.一种电子设备,其特征在于,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-3中任一项所述的方法。
8.一种存储有计算机指令的非瞬时计算机可读存储介质,其特征在于,所述计算机指令用于使所述计算机执行权利要求1-3中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010753540.2A CN111897694B (zh) | 2020-07-30 | 2020-07-30 | 小程序中消息处理方法及装置、设备、存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010753540.2A CN111897694B (zh) | 2020-07-30 | 2020-07-30 | 小程序中消息处理方法及装置、设备、存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111897694A CN111897694A (zh) | 2020-11-06 |
CN111897694B true CN111897694B (zh) | 2023-07-07 |
Family
ID=73182710
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010753540.2A Active CN111897694B (zh) | 2020-07-30 | 2020-07-30 | 小程序中消息处理方法及装置、设备、存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111897694B (zh) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112486551B (zh) * | 2020-11-26 | 2022-02-01 | 四川长虹电器股份有限公司 | 一种小程序全局实时组件的实现方法 |
CN113805910B (zh) * | 2020-11-26 | 2024-05-17 | 北京沃东天骏信息技术有限公司 | 一种应用中的数据共享的方法及系统 |
CN112596922B (zh) * | 2020-12-17 | 2024-04-05 | 百度在线网络技术(北京)有限公司 | 通信管理方法、装置、设备和介质 |
CN112765192A (zh) * | 2020-12-29 | 2021-05-07 | 广东电网有限责任公司电力科学研究院 | 一种cim模型数据变化通知方法及系统 |
CN113220472A (zh) * | 2021-04-16 | 2021-08-06 | 阿波罗智联(北京)科技有限公司 | 应用程序通信方法、设备和存储介质 |
CN113590213B (zh) * | 2021-06-24 | 2023-04-25 | 深圳开源互联网安全技术有限公司 | 组件维护方法、电子设备及存储介质 |
CN114466062B (zh) * | 2022-02-08 | 2023-10-20 | 展讯通信(天津)有限公司 | 消息分发方法和装置 |
CN115017020B (zh) * | 2022-05-06 | 2024-02-09 | 易保网络技术(上海)有限公司 | 一种小程序页面的录屏方法、介质及电子设备 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108683588A (zh) * | 2018-05-18 | 2018-10-19 | Oppo(重庆)智能科技有限公司 | 一种消息管理方法、消息管理装置及移动终端 |
US10133866B1 (en) * | 2015-12-30 | 2018-11-20 | Fireeye, Inc. | System and method for triggering analysis of an object for malware in response to modification of that object |
CN109376054A (zh) * | 2018-09-25 | 2019-02-22 | 广州虎牙信息科技有限公司 | 一种数据分发的方法、装置、终端设备及存储介质 |
CN109683880A (zh) * | 2018-12-25 | 2019-04-26 | 百度在线网络技术(北京)有限公司 | 网页交互方法、装置、设备和存储介质 |
CN109901893A (zh) * | 2017-12-07 | 2019-06-18 | 腾讯科技(武汉)有限公司 | 应用小程序的数据流管理方法 |
CN109976923A (zh) * | 2019-03-12 | 2019-07-05 | 深圳点猫科技有限公司 | 一种基于微信小程序的组件通讯实现方法及装置 |
CN111142990A (zh) * | 2019-12-06 | 2020-05-12 | 北京明略软件系统有限公司 | 一种微信小程序页面展示方法、装置、及存储介质 |
-
2020
- 2020-07-30 CN CN202010753540.2A patent/CN111897694B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10133866B1 (en) * | 2015-12-30 | 2018-11-20 | Fireeye, Inc. | System and method for triggering analysis of an object for malware in response to modification of that object |
CN109901893A (zh) * | 2017-12-07 | 2019-06-18 | 腾讯科技(武汉)有限公司 | 应用小程序的数据流管理方法 |
CN108683588A (zh) * | 2018-05-18 | 2018-10-19 | Oppo(重庆)智能科技有限公司 | 一种消息管理方法、消息管理装置及移动终端 |
CN109376054A (zh) * | 2018-09-25 | 2019-02-22 | 广州虎牙信息科技有限公司 | 一种数据分发的方法、装置、终端设备及存储介质 |
CN109683880A (zh) * | 2018-12-25 | 2019-04-26 | 百度在线网络技术(北京)有限公司 | 网页交互方法、装置、设备和存储介质 |
CN109976923A (zh) * | 2019-03-12 | 2019-07-05 | 深圳点猫科技有限公司 | 一种基于微信小程序的组件通讯实现方法及装置 |
CN111142990A (zh) * | 2019-12-06 | 2020-05-12 | 北京明略软件系统有限公司 | 一种微信小程序页面展示方法、装置、及存储介质 |
Non-Patent Citations (2)
Title |
---|
Java事件处理机制教学方法探讨;黄增喜;王晓明;于春;;福建电脑(第08期);57-58 * |
微信 APP 中在线课程教育平台的建设与教学模式创新;李娟等;信息:技术与应用;121-122 * |
Also Published As
Publication number | Publication date |
---|---|
CN111897694A (zh) | 2020-11-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111897694B (zh) | 小程序中消息处理方法及装置、设备、存储介质 | |
CN110765024B (zh) | 模拟测试方法、装置、电子设备和计算机可读存储介质 | |
CN111694857B (zh) | 存储资源数据的方法、装置、电子设备及计算机可读介质 | |
CN111913884A (zh) | 分布式测试方法、装置、设备、系统和可读存储介质 | |
JP2022003507A (ja) | ストレステスト方法及び装置、電子機器、コンピュータ可読記憶媒体並びにコンピュータプログラム | |
US10893113B2 (en) | Generating push notifications | |
CN110659184B (zh) | 健康状态检查方法、装置及系统 | |
CN111881387A (zh) | 用于小程序的数据处理方法、装置、设备和介质 | |
JP2021179994A (ja) | ページリソースを取得する方法、装置、電子機器、及び読み取り可能な記憶媒体 | |
EP2549381A2 (en) | Control computer and data accessing method | |
US20180198837A1 (en) | Streaming api subscription without loss of events | |
KR102332809B1 (ko) | 가상 스트림 및 처리 에이전트를 이용한 스트림 기반 이벤트 처리 기법 | |
CN111985760B (zh) | 数据内容的评价方法、装置、电子设备及存储介质 | |
CN111866071A (zh) | 业务应用的数据上传方法、装置、电子设备及存储介质 | |
US9032326B2 (en) | Late instantiation of dependent objects | |
CN111639116A (zh) | 数据访问连接会话保护方法以及装置 | |
US10579446B2 (en) | Per-request event detection to improve request-response latency | |
WO2019112816A1 (en) | Automatic subscription management of computing services | |
US20230368083A1 (en) | Method and apparatus for determining reservation information | |
US20170302764A1 (en) | Unifying realtime and static data for presenting over a web service | |
CN112162842A (zh) | 用于撤销请求的方法、装置、电子设备及可读存储介质 | |
CN114020741A (zh) | 车辆里程信息的存储方法、装置、车辆电子系统及车辆 | |
CN110851187A (zh) | 显存处理方法、装置、设备和介质 | |
US11362885B2 (en) | Method, apparatus, device and readable medium for disaster recovery processing for infrastructure areas | |
CN111597226A (zh) | 数据挖掘系统、方法、装置、电子设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |