[发明专利]支持多框架语法的方法和装置有效
申请号: | 201710551959.8 | 申请日: | 2017-07-07 |
公开(公告)号: | CN107423106B | 公开(公告)日: | 2021-04-23 |
发明(设计)人: | 董红光 | 申请(专利权)人: | 北京小米移动软件有限公司 |
主分类号: | G06F8/41 | 分类号: | G06F8/41 |
代理公司: | 北京英创嘉友知识产权代理事务所(普通合伙) 11447 | 代理人: | 魏嘉熹 |
地址: | 100085 北京市海淀区清河*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 支持 框架 语法 方法 装置 | ||
本公开是关于支持多框架语法的方法和装置。所述方法包括:生成对应于HTML模板和至少一个JSX模块的第一抽象语法树;确定所述第一抽象语法树中各个节点与另一指定框架的语法间的映射关系;基于所述映射关系将所述第一抽象语法树映射为所述指定框架的抽象语法树。应用本公开,有利于提高前端开发人员的开发效率,缩短开发周期。
技术领域
本公开涉及前端开发领域,尤其涉及支持多框架语法的方法和装置
背景技术
目前有多种前端开发框架,导致前端开发人员可能需要不停的学习当前需使用的开发框架,延长了开发流程,并造成对人力资源的低效使用。
发明内容
为克服相关技术中存在的问题,本公开提供一种能够支持多框架语法的方法。本公开还提出了相应的装置。
根据本公开实施例的第一方面,提供一种支持多框架语法的方法,所述方法包括:生成对应于HTML模板和至少一个JSX模块的第一抽象语法树;确定所述第一抽象语法树中各个节点与另一指定框架的语法间的映射关系;基于所述映射关系将所述第一抽象语法树映射为所述指定框架的抽象语法树。
在一种可能的实现方式中,生成与HTML模板对应的第二抽象语法树;生成与至少一个JSX模块一一对应的至少一个第三抽象语法树;将每个所述第三抽象语法树添加到所述第二抽象语法树的指定节点下,以得到所述第一抽象语法树。
在一种可能的实现方式中,所述指定框架是Vue框架、React框架或Weex框架等。
根据本公开实施例的第二方面,提供一种支持多框架语法的装置,所述装置包括:第一抽象语法树生成模块,被配置为生成对应于HTML模板和至少一个JSX模块的第一抽象语法树;映射关系确定模块,被配置为确定所述第一抽象语法树中各个节点与另一指定框架的语法间的映射关系;目标抽象语法树获取模块,被配置为基于所述映射关系将所述第一抽象语法树映射为所述指定框架的抽象语法树。
在一种可能的实现方式中,所述第一抽象语法树生成模块包括:第二抽象语法树生成子模块,被配置为生成与HTML模板对应的第二抽象语法树;第三抽象语法树生成子模块,被配置为生成与至少一个JSX模块一一对应的至少一个第三抽象语法树;合并子模块,被配置为将每个所述第三抽象语法树添加到所述第二抽象语法树的指定节点下,以得到所述第一抽象语法树。
在一种可能的实现方式中,所述指定框架是Vue框架、React框架或Weex框架等。
根据本公开实施例的第三方面,提供一种支持多框架语法的装置,其特征在于,包括:处理器;用于存储处理器可执行指令的存储器;其中,所述处理器被配置为执行如上所述的任意方法。
根据本公开实施例的第四方面,提供一种非临时性计算机可读存储介质,当所述存储介质中的指令由处理器执行时,使得处理器能够执行如上所述的任意方法。
本公开的实施例提供的技术方案可以包括以下有益效果:应用本公开,开发人员无需学习各种不同开发框架,开发人员可采用HTML模板和JSX语法进行开发,系统会自动生成对应于特定框架的抽象语法树,有利于提高前端开发人员的开发效率,缩短开发周期。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1是根据一示例性实施例示出的一种支持多框架语法的方法的流程图。
图2是根据一示例性实施例示出的一种生成第一抽象语法树的方法的流程图。
图3是根据一示例性实施例示出的一种支持多框架语法的装置的框图。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京小米移动软件有限公司,未经北京小米移动软件有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201710551959.8/2.html,转载请声明来源钻瓜专利网。
- 上一篇:拼接式多规格卫浴地板模具
- 下一篇:一种定位精准的模具