1.本公开实施例涉及计算机技术,尤其涉及一种视图展示方法、装置、设备和存储介质。
背景技术:2.随着移动互联网的快速发展,可以基于卡片形式展示移动端中的内容。目前,通常针对卡片中的每个功能区设置一个相应的功能视图,并且一些功能视图在特定交互或者条件下才会进行展示。在展示卡片时,通常会对该卡片中的所有功能视图进行创建和数据绑定,并将创建出的所有功能视图中的当前需要展示的功能视图进行渲染展示。可见,这种展示方式,卡片中的不可见功能视图也会被创建和数据绑定,从而会增大性能损耗,并且在增加新的功能区时,需要修改源代码,降低了开发效率。
技术实现要素:3.本公开实施例提供了一种视图展示方法、装置、设备和存储介质,以避免因对不可见功能视图进行创建和数据绑定而导致的性能损耗,并且具有较高的可扩展性,无需修改源代码,提高了开发效率。
4.第一方面,本公开实施例提供了一种视图展示方法,包括:
5.获取待展示卡片对应的功能区组件;
6.创建所述功能区组件中的功能视图所对应的占位视图;
7.获取所述功能区组件对应的组件数据,并基于所述组件数据确定所述功能区组件对应的组件展示标识;
8.基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
9.第二方面,本公开实施例还提供了一种视图展示装置,包括:
10.功能区组件获取模块,用于获取待展示卡片对应的功能区组件;
11.占位视图创建模块,用于创建所述功能区组件中的功能视图所对应的占位视图;
12.组件展示标识确定模块,用于获取所述功能区组件对应的组件数据,并基于所述组件数据确定所述功能区组件对应的组件展示标识;
13.数据绑定模块,用于基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
14.第三方面,本公开实施例还提供了一种电子设备,所述电子设备包括:
15.一个或多个处理器;
16.存储器,用于存储一个或多个程序;
17.当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本公开任意实施例提供的视图展示方法。
18.第四方面,本公开实施例还提供了一种计算机可读存储介质,其上存储有计算机
程序,该程序被处理器执行时实现如本公开任意实施例提供的视图展示方法。
19.本公开实施例通过针对卡片中的每个功能区设置相应的功能区组件,并针对功能区组件中的每个功能视图设置相应的占位视图,从而在展示卡片时,可以先创建出每个功能区组件中的每个功能视图所对应的占位视图,而非创建真实的功能视图,实现了功能视图的懒创建。通过获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识,并基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,从而基于组件展示标识,可以仅对可见的功能视图进行创建和数据绑定,避免了对不可见功能视图进行创建和数据绑定而导致的性能损耗。而且,在卡片需要增加新的功能区时,可以通过增加相应的功能区组件的方式进行扩展,无需修改源代码,具有较高的可扩展性,提高了开发效率。
附图说明
20.结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,原件和元素不一定按照比例绘制。
21.图1是本公开实施例一提供的一种视图展示方法的流程图;
22.图2是本公开实施例二提供的一种视图展示方法的流程图;
23.图3是本公开实施例三提供的一种视图展示装置的结构示意图;
24.图4是本公开实施例四提供的一种电子设备的结构示意图。
具体实施方式
25.下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例,相反提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
26.应当理解,本公开的方法实施方式中记载的各个步骤可以按照不同的顺序执行,和/或并行执行。此外,方法实施方式可以包括附加的步骤和/或省略执行示出的步骤。本公开的范围在此方面不受限制。
27.本文使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”;术语“另一实施例”表示“至少一个另外的实施例”;术语“一些实施例”表示“至少一些实施例”。其他术语的相关定义将在下文描述中给出。
28.需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
29.需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
30.本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
31.实施例一
32.图1为本公开实施例一提供的一种视图展示方法的流程图,本实施例可适用于以卡片形式展示移动端内容的情况。该方法可以由视图展示装置来执行,该装置可以由软件和/或硬件的方式来实现,集成于电子设备中,比如智能手机等。如图1所示,该方法具体包括以下步骤:
33.s110、获取待展示卡片对应的功能区组件。
34.其中,功能区可以是指卡片展示界面上实现特定功能的区域。例如,功能区可以是但不限于:用于展示视频内容的视频区、用于关闭视频的顶部操作栏(其可以包括一个关闭按钮,通过点击该关闭按钮关闭该视频)、用户互动栏(其可以包括一个点赞按钮、评论按钮、下载按钮和转发按钮等)、用于展示视频创作者信息的展示栏以及用于展示视频内容信息的富文本栏。每个功能区可能是可见功能区,也可能是不可见功能区,其具体基于业务需求和当前用户交互信息进行确定。例如,在播放视频时,会展示出用于展示视频创作者信息的展示栏和用于展示视频内容信息的富文本栏这两个功能区,即为可见功能区,并不会展示视频进度条和暂停按钮这两个功能区,即为不可见功能区。当检测到用户点击屏幕时,会展示出视频进度条和暂停按钮这两个功能区,即变为可见功能区,并会隐藏展示栏和富文本栏这两个功能区,即变为不可见功能区。
35.本实施例针对每个功能区设置一个独立的功能区组件。将每个功能区中的功能视图的创建逻辑和数据绑定逻辑封装到相应的一个功能区组件中,从而可以将一张复杂的卡片拆解为多个独立的功能区组件,实现功能区的高扩展和高复用。本实施例中的每个卡片可以包括一个或多个独立的功能区组件,其具体数量基于业务需求进行确定。
36.示例性地,功能区组件可以包括功能区单一组件section或者功能区集合组件sectiongroup。其中,功能区单一组件section可以是针对功能区中的所有功能视图所创建出的一个原子组件,也就是将功能区中的所有功能视图的创建逻辑和数据绑定逻辑均封装到一起的原子组件。功能区集合组件sectiongroup可以包括至少两个独立的功能区子组件。功能区子组件可以是针对功能区中的部分功能视图所创建的组件。例如,若用户互动栏对应的功能区组件为一个功能区集合组件sectiongroup,则可以针对用户互动栏中的点赞按钮、评论按钮、下载按钮和转发按钮分别设置一个功能区子组件,从而用户互动栏对应的功能区集合组件sectiongroup可以由4个独立的功能区子组件组成,以便后续需要在用户互动栏中增加新的互动按钮时,可以直接通过增加相应的功能区子组件即可,无需修改其他的源代码,进一步提高了可扩展性和可复用性。需要说明的是,功能区集合组件sectiongroup中的功能区子组件可以是功能区单一子组件(即子section),也可以是功能区集合子组件(即子sectiongroup),从而进一步提高灵活性,满足用户的个性化需求。本实施例可以通过功能区组件工厂sectionfactory(比如isectionfactory或者isectiongroupfactory),基于组件类名sectionclassname构造功能区组件(比如section或者sectiongroup)。不同卡片可以复用构造出的同一功能区组件,从而提高组件复用性。在卡片中需要增加新的功能区时,可以通过增加相应的功能区组件的方式进行扩展,无需修改源代码,从而提高了扩展性,进而也提高了开发效率。
37.具体地,可以基于用户操作确定出当前需要展示的卡片,并可以基于待展示卡片对应的根布局信息获取待展示卡片中的各个功能区组件。
38.s120、创建功能区组件中的功能视图所对应的占位视图。
39.其中,功能视图可以是指功能区中需要展示的真实视图。占位视图可以是用于对功能区组件中的功能视图进行占位的空视图。例如,占位视图可以是功能区单一组件section对应的占位视图sectionplaceholderview,或者功能区集合组件sectiongroup对应的占位视图sectiongroupplaceholderview。本实施例中的功能区组件中的每个功能视图对应一个占位视图,以便基于该占位视图可以获知创建出的功能视图对应的位置。本实施例将功能区对应的功能视图从卡片布局中抽离出来,里面只有空的占位视图,从而可以简化卡片的布局,避免了功能视图的代码在卡片布局代码里堆叠,进一步提高了可扩展性。
40.具体地,在需要创建功能视图时,先创建每个功能区组件中的功能视图对应的占位视图,而非直接创建真实的功能视图,从而利用占位视图可以实现功能视图的懒创建。
41.示例性地,s120可以包括:通过调用功能区组件对应的预设视图创建函数,创建功能区组件中的功能视图所对应的占位视图。
42.具体地,在需要创建功能视图时,可以通过调用每个功能区组件对应的预设视图创建函数oncreateview,创建出每个功能区组件对应的占位视图sectionplaceholderview或者sectiongroupplaceholderview,从而基于占位视图可以获知功能区组件中的功能视图创建后的位置。
43.s130、获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识。
44.其中,组件数据可以是指功能区组件所需要的数据。组件展示标识sectioncanshow可以用于表征功能区组件是否需要展示的标识。例如,组件展示标识可以包括:预设展示标识和预设隐藏标识。预设展示标识可以是预先设置的,用于表征功能区组件需要展示的标识,比如,预设展示标识为true。预设隐藏标识可以是预先设置的,用于表征功能区组件不需要展示的标识,比如,预设展示标识为false。
45.具体地,可以通过递归方式,调用每个功能区组件对应的数据解析函数isectiondataparser,从数据源中提取出每个功能区组件所需要的组件数据,并可以将组件数据存储至相应的数据存储单元中sectiondatafetcher。针对每个功能区组件,可以基于功能区组件对应的组件数据中是否存在有可展示的功能视图数据,若存在,则表明该功能区组件中的各个功能视图需要展示,此时可以确定该功能区组件对应的组件展示标识为预设展示标识,否则,确定该功能区组件对应的组件展示标识为预设隐藏标识。例如,若功能区组件是用于展示视频创作者信息的展示栏的组件,则在组件数据包含有视频创作者信息时,确定该功能区组件对应的组件展示标识为预设展示标识,在组件数据未包含有视频创作者信息时,确定该功能区组件对应的组件展示标识为预设隐藏标识。
46.示例性地,s130中的“基于组件数据确定功能区组件对应的组件展示标识”可以包括:获取功能区组件对应的上下文信息;基于组件数据和上下文信息,确定功能区组件对应的组件展示标识。
47.具体地,每个功能区组件中还封装有与其他功能区组件或者上下文进行通信的逻辑,从而针对每个功能区组件,可以获取该功能区组件对应的上下文信息sectioncontext,并同时基于组件数据和上下文信息,确定出该功能区组件对应的组件展示标识。例如,在组件数据中包含有可展示的功能视图数据,和/或基于上下文信息确定需要展示该功能区组件中的功能视图时,可以确定该功能区组件对应的组件展示标识为预设展示标识,否则确
定该组件展示标识为预设隐藏标识。通过同时基于组件数据和上下文信息,可以更加准确全面地确定出组件展示标识,并且也可以满足个性化需求,进一步提高开发效率。
48.s140、基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
49.具体地,可以通过根功能区集合组件rootsectiongroup(即最外层的功能区组件),将功能视图的创建行为和数据绑定行为一层一层的分发到里面的功能区组件section或者sectiongroup中,以使每个功能区组件基于组件展示标识进行功能视图的创建和数据绑定,从而完成卡片中完整的功能视图的创建和数据绑定操作。本实施例可以仅对组件展示标识为预设展示标识的各个功能区组件中的功能视图进行创建和数据绑定,即对可见的功能视图进行创建和数据绑定,无需对组件展示标识为预设隐藏标识的各个功能区组件中的功能视图进行创建和数据绑定,从而基于组件展示标识这一数据流驱动的方式可以将功能视图的创建操作延后到数据绑定的时候,实现了功能视图的懒创建,进而避免了对不可见功能视图进行创建和数据绑定而导致的性能损耗。
50.示例性地,s140可以包括:通过调用功能区组件对应的预设数据绑定函数,基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定。
51.具体地,在功能视图需要绑定数据时,可以通过调用每个功能区组件对应的预设数据绑定函数trybinddata,基于每个功能区组件对应的组件展示标识、占位视图和组件数据,对可见的功能区组件中的各个功能视图进行创建和数据绑定。需要说明的的是,预设数据绑定函数trybinddata与现有的数据绑定函数onbindview不同,trybinddata是尝试进行数据绑定,仅对可见的功能视图进行创建和数据绑定,从而可以避免对不可见功能视图进行创建和数据绑定所造成的性能损耗,进而提高了运行性能。
52.本公开实施例的技术方案,通过针对卡片中的每个功能区设置相应的功能区组件,并针对功能区组件中的每个功能视图设置相应的占位视图,从而在展示卡片时,可以先创建出每个功能区组件中的每个功能视图所对应的占位视图,而非创建真实的功能视图,实现了功能视图的懒创建。通过获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识,并基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,从而基于组件展示标识,可以仅对可见的功能视图进行创建和数据绑定,避免了对不可见功能视图进行创建和数据绑定而导致的性能损耗。而且,在卡片需要增加新的功能区时,可以通过增加相应的功能区组件的方式进行扩展,无需修改源代码,具有较高的可扩展性,提高了开发效率。
53.在上述技术方案的基础上,s110可以包括:基于待展示卡片对应的根布局信息,创建待展示卡片对应的根功能区集合组件,其中,根布局信息包括占位视图信息;基于根功能区集合组件,获取待展示卡片对应的功能区组件。
54.具体地,可以在待展示卡片的根布局中申明该卡片中所需要包含的各个功能区组件对应的各个占位视图信息,即sectionplaceholderview或者sectiongroupplaceholderview,从而获得待展示卡片对应的根布局信息,基于该根布局信息可以创建出一个根功能区集合组件rootsectiongroup,该根功能区集合组件rootsectiongroup可以自动采集根布局中的每个占位视图信息对应的功能区组件,从而获得待展示卡片对应的所有功能区组件section和sectiongroup。
55.示例性地,s140可以包括:若组件展示标识为预设展示标识,则基于占位视图,创建功能区组件中的功能视图,并基于组件数据,对创建出的功能视图进行数据绑定;若组件展示标识为预设隐藏标识,则对功能区组件中的功能视图进行隐藏。
56.具体地,通过根功能区集合组件rootsectiongroup,将功能视图的创建行为和数据绑定行为一层一层的分发到里面的每个功能区组件section或者sectiongroup中,并检测组件展示标识是预设展示标识还是预设隐藏标识,在为预设展示标识时,可以通过调用视图创建子函数createview(),在占位视图所在位置上创建出相应的功能视图,从而将占位视图替换为创建出的功能视图,并可以通过调用数据绑定子函数binddata(),确定出组件数据中的每个功能视图对应的视图数据,并对创建出的功能视图进行视图数据的绑定,并将绑定后的功能视图状态设置为可见状态visible,以便对该功能视图进行渲染展示。在为预设隐藏标识时,可以直接隐藏该功能区组件中的所有功能视图,比如将该功能区组件对应的功能视图状态设置为隐藏状态gone,从而可以避免对该功能区组件进行视图创建和数据绑定而导致的性能损耗。
57.示例性地,基于占位视图,创建功能区组件中的功能视图,可以包括:检测功能区组件中的每个功能视图是否已经创建;若是,则对已创建的该功能视图进行初始化;若否,则在该功能视图对应的占位视图所在位置上,创建该功能视图。
58.具体地,若某个功能视图是首次展示,则表明之前未创建过该功能视图,此时可以通过调用视图创建子函数createview(),在该功能视图对应的占位视图所在位置上,创建该功能视图,从而将占位视图替换为功能区组件创建出的功能视图。若某个功能视图非首次展示,则表明之前已创建过该功能视图,此时可以通过调用初始化函数sectioninitview(),直接对该功能视图进行初始化,以便对初始化后的功能视图进行视图数据的绑定操作,从而实现了功能视图的复用性,进一步提高了展示性能。
59.实施例二
60.图2为本公开实施例二提供的一种视图展示方法的流程图,本实施例在上述实施例的基础上,对功能区单一组件和功能区集合组件中的功能视图的具体展示方式进行了详细描述。其中与上述各实施例相同或相应的术语的解释在此不再赘述。
61.参见图2,本实施例提供的视图展示方法具体包括以下步骤:
62.s210、获取待展示卡片对应的功能区组件。
63.s220、创建功能区组件中的功能视图所对应的占位视图。
64.s230、获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识。
65.s240、若组件展示标识为预设展示标识,则检测功能区组件为功能区单一组件还是功能区集合组件,若是功能区单一组件,则执行步骤s250;若是功能区集合组件,则执行步骤s260。
66.具体地,针对每个功能区组件而言,若该功能区组件对应的组件展示标识为预设展示标识,则表明需要对该功能区组件中的各个功能视图进行展示,此时可以检测该功能区组件是未存在嵌套的功能区单一组件section还是存在嵌套的功能区集合组件sectiongroup。
67.s250、基于占位视图,创建功能区组件中的功能视图,并基于组件数据,对创建出
的功能视图进行数据绑定,并展示数据绑定后的功能视图。
68.具体地,在该功能区组件是未存在嵌套的功能区单一组件section时,可以直接基于占位视图,创建该功能区组件中的各个功能视图,并基于该功能区组件对应的组件数据,获得每个功能视图对应的视图数据,并将视图数据绑定到相应的功能视图上,通过展示数据绑定后的各个功能视图,从而可以实现卡片的展示。
69.s260、基于组件数据,确定功能区集合组件中的每个功能区子组件对应的子组件数据,并基于子组件数据确定每个功能区子组件对应的子组件展示标识。
70.具体地,在该功能区组件是存在嵌套的功能区集合组件sectiongroup时,可以将该功能区集合组件的组件数据分发至所包含的各个功能区子组件中,获得每个功能区子组件对应的子组件数据,并可以基于每个子组件数据是否包含有可展示的功能视图数据,和/或基于每个功能区子组件的上下文信息确定需要展示该功能区子组件中的功能视图时,可以确定出每个功能区子组件对应的子组件展示标识为预设展示标识,否则确定该功能区子组件对应的子组件展示标识为预设隐藏标识。
71.s270、基于子组件展示标识、功能区子组件对应的占位视图和子组件数据,对每个功能区子组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
72.具体地,对于功能区集合组件sectiongroup中的各个功能区子组件而言,可以仅对子组件展示标识为预设展示标识的功能区子组件中的功能视图进行创建和数据绑定,即对可见的功能视图进行创建和数据绑定,无需对子组件展示标识为预设隐藏标识的功能区子组件中的功能视图进行创建和数据绑定,从而可以对功能区集合组件sectiongroup中的部分功能区子组件进行展示,进一步提高展示的灵活性,满足用户的个性化需求。
73.需要说明的是,功能区子组件可以是功能区单一子组件(即子section),也可以是功能区集合子组件(即子sectiongroup),若为功能区单一子组件,则可以基于该子组件展示标识进行功能视图的创建和数据绑定,以避免对不可见功能视图进行创建和数据绑定而导致的性能损耗。若为功能区集合子组件,则基于上述类似的过程,一层一层地确定该功能区集合子组件中所嵌套的各个子组件,直到子组件为功能区单一子组件为止。通过设置功能区集合组件的方式,可以进一步提高灵活性,满足用户的个性化需求,并且提高开发效率。
74.s280、若组件展示标识为预设隐藏标识,则对功能区组件中的功能视图进行隐藏。
75.本实施例的技术方案,通过在功能区组件为功能区集合组件时,基于组件数据,确定功能区集合组件中的每个功能区子组件对应的子组件数据,并基于子组件数据确定每个功能区子组件对应的子组件展示标识,基于子组件展示标识、功能区子组件对应的占位视图和子组件数据,对每个功能区子组件中的功能视图进行创建和数据绑定,从而可以一层一层地进行功能视图的创建和数据绑定,进而提高了灵活性,满足用户的个性化需求,并且也提高了开发效率。
76.以下是本公开实施例提供的视图展示装置的实施例,该装置与上述实施例的视图展示方法属于同一个发明构思,在视图展示装置的实施例中未详尽描述的细节内容,可以参考上述实施例的视图展示方法。
77.实施例三
78.图3为本公开实施例三提供的一种视图展示装置的结构示意图。如图3所示,该装
置具体包括:功能区组件获取模块310、占位视图创建模块320、组件展示标识确定模块330和数据绑定模块340。
79.其中,功能区组件获取模块310,用于获取待展示卡片对应的功能区组件;占位视图创建模块320,用于创建功能区组件中的功能视图所对应的占位视图;组件展示标识确定模块330,用于获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识;数据绑定模块340,用于基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
80.本公开实施例的技术方案,通过针对卡片中的每个功能区设置相应的功能区组件,并针对功能区组件中的每个功能视图设置相应的占位视图,从而在展示卡片时,可以先创建出每个功能区组件中的每个功能视图所对应的占位视图,而非创建真实的功能视图,实现了功能视图的懒创建。通过获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识,并基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,从而基于组件展示标识,可以仅对可见的功能视图进行创建和数据绑定,避免了对不可见功能视图进行创建和数据绑定而导致的性能损耗。而且,在卡片需要增加新的功能区时,可以通过增加相应的功能区组件的方式进行扩展,无需修改源代码,具有较高的可扩展性,提高了开发效率。
81.在上述技术方案的基础上,功能区组件包括:功能区单一组件或者功能区集合组件,其中,功能区集合组件包括至少两个功能区子组件。
82.在上述各技术方案的基础上,功能区组件获取模块310,具体用于:
83.基于待展示卡片对应的根布局信息,创建待展示卡片对应的根功能区集合组件,其中,根布局信息包括占位视图信息;基于根功能区集合组件,获取待展示卡片对应的功能区组件。
84.在上述各技术方案的基础上,组件展示标识确定模块330,具体用于:
85.获取功能区组件对应的上下文信息;基于组件数据和上下文信息,确定功能区组件对应的组件展示标识。
86.在上述各技术方案的基础上,数据绑定模块340,包括:
87.功能视图创建绑定单元,用于若组件展示标识为预设展示标识,则基于占位视图,创建功能区组件中的功能视图,并基于组件数据,对创建出的功能视图进行数据绑定;
88.功能视图隐藏单元,用于若组件展示标识为预设隐藏标识,则对功能区组件中的功能视图进行隐藏。
89.在上述各技术方案的基础上,功能视图创建绑定单元,具体用于:
90.检测功能区组件中的每个功能视图是否已经创建;若是,则对已创建的该功能视图进行初始化;若否,则在该功能视图对应的占位视图所在位置上,创建该功能视图。
91.在上述各技术方案的基础上,功能视图创建绑定单元,还具体用于:
92.若功能区组件为功能区集合组件,则基于组件数据,确定功能区集合组件中的每个功能区子组件对应的子组件数据,并基于子组件数据确定每个功能区子组件对应的子组件展示标识;基于子组件展示标识、功能区子组件对应的占位视图和子组件数据,对每个功能区子组件中的功能视图进行创建和数据绑定。
93.在上述各技术方案的基础上,占位视图创建模块320,具体用于:通过调用功能区
组件对应的预设视图创建函数,创建功能区组件中的功能视图所对应的占位视图。
94.在上述各技术方案的基础上,数据绑定模块340,具体用于:通过调用功能区组件对应的预设数据绑定函数,基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定。
95.本公开实施例所提供的视图展示装置可执行本发明任意实施例所提供的视图展示方法,具备执行视图展示方法相应的功能模块和有益效果。
96.值得注意的是,上述视图展示装置的实施例中,所包括的各个单元和模块只是按照功能逻辑进行划分的,但并不局限于上述的划分,只要能够实现相应的功能即可;另外,各功能单元的具体名称也只是为了便于相互区分,并不用于限制本发明的保护范围。
97.实施例四
98.下面参考图4,其示出了适于用来实现本公开实施例的电子设备900的结构示意图。图4示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
99.如图4所示,电子设备900可以包括处理装置(例如中央处理器、图形处理器等)901,其可以根据存储在只读存储器(rom)902中的程序或者从存储装置908加载到随机访问存储器(ram)903中的程序而执行各种适当的动作和处理。在ram 903中,还存储有电子设备900操作所需的各种程序和数据。处理装置901、rom 902以及ram 903通过总线904彼此相连。输入/输出(i/o)接口905也连接至总线904。
100.通常,以下装置可以连接至i/o接口905:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置906;包括例如液晶显示器(lcd)、扬声器、振动器等的输出装置907;包括例如磁带、硬盘等的存储装置908;以及通信装置909。通信装置909可以允许电子设备900与其他设备进行无线或有线通信以交换数据。虽然图4示出了具有各种装置的电子设备900,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
101.特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在非暂态计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信装置909从网络上被下载和安装,或者从存储装置908被安装,或者从rom 902被安装。在该计算机程序被处理装置901执行时,执行本公开实施例的方法中限定的上述功能。
102.本公开实施例提供的电子设备与上述实施例提供的视频卡顿预测方法属于同一发明构思,未在本公开实施例中详尽描述的技术细节可参见上述实施例,并且本公开实施例与上述实施例具有相同的有益效果。
103.实施例五
104.本公开实施例提供了一种计算机存储介质,其上存储有计算机程序,该程序被处理器执行时实现上述实施例所提供的视图展示方法。
105.需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计
算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑磁盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、rf(射频)等等,或者上述的任意合适的组合。
106.在一些实施方式中,客户端、服务器可以利用诸如http(hypertext transfer protocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“lan”),广域网(“wan”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
107.上述计算机可读介质可以是上述客户端中所包含的;也可以是单独存在,而未装配入该客户端中。
108.上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该客户端执行时,使得该客户端:获取待展示卡片对应的功能区组件;创建功能区组件中的功能视图所对应的占位视图;获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识;基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
109.可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括但不限于面向对象的程序设计语言—诸如java、smalltalk、c++,还包括常规的过程式程序设计语言—诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(lan)或广域网(wan)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
110.附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执
行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
111.描述于本公开实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,单元的名称在某种情况下并不构成对该单元本身的限定,例如,可编辑内容显示单元还可以被描述为“编辑单元”。
112.本文中以上描述的功能可以至少部分地由一个或多个硬件逻辑部件来执行。例如,非限制性地,可以使用的示范类型的硬件逻辑部件包括:现场可编程门阵列(fpga)、专用集成电路(asic)、专用标准产品(assp)、片上系统(soc)、复杂可编程逻辑设备(cpld)等等。
113.在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦除可编程只读存储器(eprom或快闪存储器)、光纤、便捷式紧凑盘只读存储器(cd-rom)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
114.根据本公开的一个或多个实施例,【示例一】提供了一种视图展示方法,包括:
115.获取待展示卡片对应的功能区组件;
116.创建所述功能区组件中的功能视图所对应的占位视图;
117.获取所述功能区组件对应的组件数据,并基于所述组件数据确定所述功能区组件对应的组件展示标识;
118.基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
119.根据本公开的一个或多个实施例,【示例二】提供了一种视图展示方法,还包括:
120.可选的,所述功能区组件包括:功能区单一组件或者功能区集合组件,其中,所述功能区集合组件包括至少两个功能区子组件。
121.根据本公开的一个或多个实施例,【示例三】提供了一种视图展示方法,还包括:
122.可选的,所述获取待展示卡片对应的功能区组件,包括:
123.基于待展示卡片对应的根布局信息,创建所述待展示卡片对应的根功能区集合组件,其中,所述根布局信息包括占位视图信息;
124.基于所述根功能区集合组件,获取所述待展示卡片对应的功能区组件。
125.根据本公开的一个或多个实施例,【示例四】提供了一种视图展示方法,还包括:
126.可选的,所述基于所述组件数据确定所述功能区组件对应的组件展示标识,包括:
127.获取所述功能区组件对应的上下文信息;
128.基于所述组件数据和所述上下文信息,确定所述功能区组件对应的组件展示标识。
129.根据本公开的一个或多个实施例,【示例五】提供了一种视图展示方法,还包括:
130.可选的,所述基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能
区组件中的功能视图进行创建和数据绑定,包括:
131.若所述组件展示标识为预设展示标识,则基于所述占位视图,创建所述功能区组件中的功能视图,并基于所述组件数据,对创建出的功能视图进行数据绑定;
132.若所述组件展示标识为预设隐藏标识,则对所述功能区组件中的功能视图进行隐藏。
133.根据本公开的一个或多个实施例,【示例六】提供了一种视图展示方法,还包括:
134.可选的,所述基于所述占位视图,创建所述功能区组件中的功能视图,包括:
135.检测所述功能区组件中的每个功能视图是否已经创建;
136.若是,则对已创建的该功能视图进行初始化;
137.若否,则在该功能视图对应的占位视图所在位置上,创建该功能视图。
138.根据本公开的一个或多个实施例,【示例七】提供了一种视图展示方法,还包括:
139.可选的,所述基于所述占位视图,创建所述功能区组件中的功能视图,并基于所述组件数据,对创建出的功能视图进行数据绑定,包括:
140.若所述功能区组件为功能区集合组件,则基于所述组件数据,确定所述功能区集合组件中的每个功能区子组件对应的子组件数据,并基于所述子组件数据确定每个所述功能区子组件对应的子组件展示标识;
141.基于所述子组件展示标识、所述功能区子组件对应的占位视图和所述子组件数据,对每个所述功能区子组件中的功能视图进行创建和数据绑定。
142.根据本公开的一个或多个实施例,【示例八】提供了一种视图展示方法,还包括:
143.可选的,所述创建所述功能区组件中的功能视图所对应的占位视图,包括:
144.通过调用所述功能区组件对应的预设视图创建函数,创建所述功能区组件中的功能视图所对应的占位视图。
145.根据本公开的一个或多个实施例,【示例九】提供了一种视图展示方法,还包括:
146.可选的,所述基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,包括:
147.通过调用所述功能区组件对应的预设数据绑定函数,基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定。
148.根据本公开的一个或多个实施例,【示例十】提供了一种视图展示装置,包括:
149.功能区组件获取模块,用于获取待展示卡片对应的功能区组件;
150.占位视图创建模块,用于创建所述功能区组件中的功能视图所对应的占位视图;
151.组件展示标识确定模块,用于获取所述功能区组件对应的组件数据,并基于所述组件数据确定所述功能区组件对应的组件展示标识;
152.数据绑定模块,用于基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。
153.以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
154.此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本公开的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
155.尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。
技术特征:1.一种视图展示方法,其特征在于,包括:获取待展示卡片对应的功能区组件;创建所述功能区组件中的功能视图所对应的占位视图;获取所述功能区组件对应的组件数据,并基于所述组件数据确定所述功能区组件对应的组件展示标识;基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。2.根据权利要求1所述的方法,其特征在于,所述功能区组件包括:功能区单一组件或者功能区集合组件,其中,所述功能区集合组件包括至少两个功能区子组件。3.根据权利要求1所述的方法,其特征在于,所述获取待展示卡片对应的功能区组件,包括:基于待展示卡片对应的根布局信息,创建所述待展示卡片对应的根功能区集合组件,其中,所述根布局信息包括占位视图信息;基于所述根功能区集合组件,获取所述待展示卡片对应的功能区组件。4.根据权利要求1所述的方法,其特征在于,所述基于所述组件数据确定所述功能区组件对应的组件展示标识,包括:获取所述功能区组件对应的上下文信息;基于所述组件数据和所述上下文信息,确定所述功能区组件对应的组件展示标识。5.根据权利要求1所述的方法,其特征在于,所述基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,包括:若所述组件展示标识为预设展示标识,则基于所述占位视图,创建所述功能区组件中的功能视图,并基于所述组件数据,对创建出的功能视图进行数据绑定;若所述组件展示标识为预设隐藏标识,则对所述功能区组件中的功能视图进行隐藏。6.根据权利要求5所述的方法,其特征在于,所述基于所述占位视图,创建所述功能区组件中的功能视图,包括:检测所述功能区组件中的每个功能视图是否已经创建;若是,则对已创建的该功能视图进行初始化;若否,则在该功能视图对应的占位视图所在位置上,创建该功能视图。7.根据权利要求5所述的方法,其特征在于,所述基于所述占位视图,创建所述功能区组件中的功能视图,并基于所述组件数据,对创建出的功能视图进行数据绑定,包括:若所述功能区组件为功能区集合组件,则基于所述组件数据,确定所述功能区集合组件中的每个功能区子组件对应的子组件数据,并基于所述子组件数据确定每个所述功能区子组件对应的子组件展示标识;基于所述子组件展示标识、所述功能区子组件对应的占位视图和所述子组件数据,对每个所述功能区子组件中的功能视图进行创建和数据绑定。8.根据权利要求1所述的方法,其特征在于,所述创建所述功能区组件中的功能视图所对应的占位视图,包括:通过调用所述功能区组件对应的预设视图创建函数,创建所述功能区组件中的功能视图所对应的占位视图。
9.根据权利要求1所述的方法,其特征在于,所述基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,包括:通过调用所述功能区组件对应的预设数据绑定函数,基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定。10.一种视图展示装置,其特征在于,包括:功能区组件获取模块,用于获取待展示卡片对应的功能区组件;占位视图创建模块,用于创建所述功能区组件中的功能视图所对应的占位视图;组件展示标识确定模块,用于获取所述功能区组件对应的组件数据,并基于所述组件数据确定所述功能区组件对应的组件展示标识;数据绑定模块,用于基于所述组件展示标识、所述占位视图和所述组件数据,对所述功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。11.一种电子设备,其特征在于,所述电子设备包括:一个或多个处理器;存储器,用于存储一个或多个程序;当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-9中任一所述的视图展示方法。12.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-9中任一所述的视图展示方法。
技术总结本公开实施例公开了一种视图展示方法、装置、设备和存储介质。该方法包括:获取待展示卡片对应的功能区组件;创建功能区组件中的功能视图所对应的占位视图;获取功能区组件对应的组件数据,并基于组件数据确定功能区组件对应的组件展示标识;基于组件展示标识、占位视图和组件数据,对功能区组件中的功能视图进行创建和数据绑定,并展示数据绑定后的功能视图。通过本公开实施例的技术方案,可以避免因对不可见功能视图进行创建和数据绑定而导致的性能损耗,并且具有较高的可扩展性,无需修改源代码,提高了开发效率。提高了开发效率。提高了开发效率。
技术研发人员:魏申鸿
受保护的技术使用者:北京字跳网络技术有限公司
技术研发日:2022.04.11
技术公布日:2022/7/5