为什么#
openlayers 的 API 文档内容是极好的,然而使用起来却一言难尽。
一般的查 api 的方式有以下两种:
- 搜索引擎 👉 openlayers + 关键字 👉 打开指定链接
- 打开 api doc 页面 👉 搜索关键字 👉 通过搜索结果到达指定结果
OL Search 1#
OL Search 是一款浏览器拓展(目前只上架了 Edge add-ons2),可以通过浏览器地址栏快捷搜索 openlayers api,步骤如下:
- control+L 或者 cmd+L 进入搜索栏。
- 输入
ol
关键字,tab 或者 space 进入 OL Search。 - 输入目标 api (方法、成员变量、触发器等)的关键字,选择指定链接直达。
实现#
主要分三步:
解析 api 文档#
https://openlayers.org/en/latest/apidoc/navigation.tmpl.html
文档的导航栏部分镶嵌了一个 HTML,来自上面的地址。
这里本来有两个思路。
一是通过修改 openlayers 自己的 api build
的脚本生成一组与上述 HTML 内容一致的 JSON 格式的 api 文档信息。
但考虑到两点:
- 后期维护问题,如果这么做,每个小版本更新需要重新更新插件。
- 插件体积变大。
另一种是直接解析上面的 HTML 的导航信息文件,这里遇到了问题,因为在浏览器的插件中,backgroud.js
里无法访问DOMParser
对象,这里走了弯路,最开始曲线救国,通过popup
(点击拓展图标显示的小弹窗) 加载数据。这种方式缺点很明显,用户安装完插件后无法直接使用,需要点击拓展图标等待索引文件初始化后才能使用。之后找到了一个纯javascript
的 DOM 解析库,才解决了该问题。
模糊搜索#
最开始的时候采用硬搜索,自己使用起来都不满意,因为打字偶尔的 typo 不可避免,因此模糊搜索应该是刚需。
这里参考了mdn-search 的做法,引入了fuse.js
。也做了一些多关键字的增强。
比如在搜索readFeatures
这个方法的时候,各种格式例如EsriJSON
、KML
、WKT
等都有readFeatures
方法,而默认搜索结果WKT
在后面,假如我想找WKT
的readFeatures
的话就会影响体验。
通过fuse.js
的search.$or
,实现了多关键字的复合搜索。
这样只需要输入readFeatures wkt
就可以将包含WKT
的结果提到第一个候选。
干掉默认推荐#
在监听地址栏omnibox
内容变化事件的回调函数中,浏览器默认会在你给的推荐结果前面默认加一条默认推荐,其内容是你键入的内容,指向的地址是你拓展的地址加上该内容。默认行为即File not found
。
这部分思路来自rust-search-extension ,首先根据用户的键入内容结合搜索结果,将默认推荐设置为原本的第二条结果(真正搜索结果的第一顺位),之后在用户回车后判断该选项是否是默认建议,如果是,则指向真正搜索结果的第一顺位的地址。
最后#
希望该工具给重度使用 openlayers api doc 的各位同仁带来帮助。
Footnotes#
-
OL Search repo: https://github.com/yuhangch/ol-search ↩
-
Edge Add-ons: https://microsoftedge.microsoft.com/addons/detail/ol-search/feooodhgjmplabaneabphdnbljlelgka ↩