npm 包 graphql-osm 使用教程

GraphQL-OSM 是一个利用 GraphQL 技术实现的 OpenStreetMap 数据库查询工具。它提供了一些方便的 GraphQL 接口,可以帮助我们快速地查询 OSM 数据库中的信息。本文将介绍如何使用 npm 包 graphql-osm,包括安装、示例代码以及使用技巧。

安装

我们可以使用 npm 命令来安装 graphql-osm:

--- ------- -----------

或者在 package.json 中添加依赖:

-
  --------------- -
    -------------- --------
  -
-

使用示例

接下来我们将演示如何使用 graphql-osm 获取 OSM 数据库中的信息。首先我们需要创建一个 GraphQL 客户端,然后使用 GraphQL 查询语句向服务器发送请求,最后得到返回的结果。

创建 GraphQL 客户端

我们可以使用 graphql-osm 包提供的 createClient 函数来创建一个 GraphQL 客户端,代码如下:

----- - ------------ - - -----------------------

----- ------ - --------------
  ---- ------------------------------------------
  -------- ---
---

其中 url 指定 OpenStreetMap 数据库的 URL,headers 指定 HTTP 请求头部的内容,可选。

向服务器发送请求

我们可以使用 GraphQL 查询语句来向服务器发送请求。例如下面的查询语句可以获取一个区域内的所有餐厅:

----- -
  ---------- -------- ------ ------- ------- ----- --------- -------------- -
    --
    ----
  -
-

此代码的查询区域是北京市海淀区,西南角为 (116.31, 39.96),东北角为 (116.51, 40.06)。查询条件是获取所有 amenity=restaurant 的节点。

我们可以使用 client.query 函数向服务器发送请求并解析结果,代码如下:

----- ----- - -
  ----- -
    ---------- -------- ------ ------- ------- ----- --------- -------------- -
      --
      ----
    -
  -
--

--------------------------------- -- -
  --------------------
---

解析结果

GraphQL 的查询结果是一个携带数据的 JSON 对象。我们可以使用 JavaScript 对象的方式来访问查询结果中的数据。例如下面的 JavaScript 代码可以输出所有餐厅的名称:

----- ----- - -
  ----- -
    ---------- -------- ------ ------- ------- ----- --------- -------------- -
      --
      ---- -
        ----
      -
    -
  -
--

--------------------------------- -- -
  ----- ----- - -----------------
  --- ---- - - -- - - ------------- ---- -
    ----- ---- - --------------
    -- ----- -- ---------- -
      -----------------------
    -
  -
---

使用技巧

指定区域

通过指定查询区域,我们可以限制查询的范围。可以使用 bbox 参数来指定查询区域的边界坐标,例如:

----- -
  ---------- -------- ------ ------- ------- ----- --------- -------------- -
    --
    ----
  -
-

过滤条件

我们可以通过查询条件来筛选目标节点。例如下面的查询条件可以获取所有 amenity=restaurant 并且 name 包含 ‘KFC’ 的节点:

----- -
  ---------- -------- ------ ------- ------- ----- --------- ------------- ----- ------- -
    --
    ----
  -
-

查询多种类型的节点

除了查询 node 节点之外,我们还可以查询 wayrelation 节点,例如:

----- -
  ---------- -------- ------ ------- ------- ----- --------- -------------- -
    --
    ----
  -
  --------- -------- ------ ------- ------- ----- --------- ------------ -
    --
    ----
  -
  -------------- -------- ------ ------- ------- ----- ------ -------- ------ ----------- -
    --
    ----
  -
-

查询节点属性

除了查询节点的 id 和 tags 之外,我们还可以查询节点的位置信息、版本信息等属性。例如下面的查询条件可以获取 amenity=restaurant 的节点的位置信息:

----- -
  ---------- -------- ------ ------- ------- ----- --------- -------------- -
    --
    ---
    ---
    -------
  -
-

结论

通过本文的介绍,我们学习了如何使用 npm 包 graphql-osm 完成 OSM 数据库的查询和解析。GraphQL-OSM 提供了一些方便的接口,我们可以通过指定查询区域和查询条件来获取特定类型的节点信息。同时,我们也介绍了一些常见的查询技巧。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/60065f8f238a385564ab6f49


猜你喜欢

  • npm 包 fp-recursion 使用教程

    简介 在函数式编程中,递归经常被用来处理非常常见的问题,例如树形结构的遍历和处理。但是,使用 JavaScript 内置的递归函数通常会导致栈溢出错误。因此,需要一种方法来避免这个问题。

    3 年前
  • npm 包 if-win-backslash 使用教程

    在前端开发过程中,我们经常会面临跨平台文件路径的问题。Windows 下使用的反斜杠(\)在 Unix 系统上是不被识别的,而 Unix 系统下使用的正斜杠(/)在 Windows 系统上也只有在特定...

    3 年前
  • npm 包 nikud.js 使用教程

    介绍 nikud.js 是一个用于处理带有音标的希伯来语文本的 npm 包。它可以将希伯来语文本中的音标转换为 Unicode 范畴 P 字母表中的字符。此外,nikud.js 还提供了一组工具函数,...

    3 年前
  • npm 包 pandoc-index 使用教程

    前言 在进行前端开发过程中,我们经常需要对我们的文档进行管理和编写,这就需要我们使用到一些常用的文档工具。而 pandoc-index 就是一款非常实用的 npm 包,它可以帮助我们管理和编写文档,并...

    3 年前
  • npm 包 parse-server-fs-store-adapter 使用教程

    介绍 在构建 web 应用程序时,经常需要将文件上传到服务器。parse-server-fs-store-adapter 是一种可用于存储和检索 parse-server 文件的 npm 包。

    3 年前
  • NPM 包 react-swipy 使用教程

    前言 react-swipy 是一个基于 React 的轻量级拖拽交互组件库,提供了拖拽、滑动等手势的支持。如果您正在开发一个需要拖拽或滑动功能的 React 应用程序,那么 react-swipy ...

    3 年前
  • npm 包 babel-plugin-all-curried 使用教程

    前言 在前端开发过程中,我们常常需要用到函数式编程。然而,常规的 JavaScript 函数并不能够直接支持函数柯里化,这就导致我们需要手动写一些辅助函数来实现柯里化。

    3 年前
  • npm 包 react-site-menu 使用教程

    React-site-menu 是一个专门设计用于前端开发的 npm 包。它可以让您在 React 应用程序中轻松实现导航菜单,这是一个常见且必备的功能。本文将详细介绍 react-site-menu...

    3 年前
  • npm 包 censorify0.1.1 使用教程

    前言 在前端开发中,我们经常需要对用户输入的文章或评论进行过滤,以屏蔽敏感词或不良信息。censorify0.1.1 这个 npm 包可以方便地实现这个功能,本文将详细介绍如何使用这个技术包。

    3 年前
  • npm 包 watch-gh-repos 使用教程

    在前端开发中,我们经常需要关注 GitHub 上的项目,以便及时获取最新的更新并快速作出反应。然而,手动去检查项目更新比较繁琐,而且容易漏掉某些变化。这时候,一个自动化的工具 watch-gh-rep...

    3 年前
  • npm 包 @huston007/react-native-image-picker 使用教程

    前言 在如今的移动端开发中,图片上传功能是一个常见的需求,尤其在需要用户上传头像、图像内容展示等业务中。而在 React Native 中,我们可以使用 @huston007/react-native...

    3 年前
  • npm 包 ngx-forge-jyas 使用教程

    在前端开发中,我们经常需要使用各种第三方工具和库来提高开发效率和代码质量。其中,npm 是一个非常流行的包管理器,可以帮助我们快速安装和管理各种项目依赖。ngx-forge-jyas 是一个基于 An...

    3 年前
  • npm 包 react-native-tpush 使用教程

    如果你正在开发无线应用,可能需要使用推送通知服务。而 TPush 是移动推送 SDK 中的一种,它提供了 Android 和 iOS 平台的推送服务。React Native 是一种流行的 JavaS...

    3 年前
  • bragg-sqs:一个高效的 Node.js SQS 处理库

    作为前端开发工程师,我们经常需要使用第三方库来实现复杂的功能。如何找到一个高效的库并学会使用它,是前端开发的重要一环。本文将为大家介绍一个高效的 Node.js SQS 处理库:bragg-sqs,并...

    3 年前
  • npm 包 jmazm-koa-static-cache 使用教程

    前言 在前端开发中,我们经常会需要使用到静态资源。静态资源包括但不限于 HTML、CSS、JavaScript、图片、视频等等。如果静态资源很大,每次请求都去读取磁盘或者 CDN 带来的 I/O 消耗...

    3 年前
  • npm 包 chartist-logscale 使用教程

    简介 Chartist-logscale 是一个能够在 Chart.js 中使用对数刻度的 npm 包。对数刻度在处理大量数据时非常有用,它能够将非线性数据转换为线性数据,从而更好地展示数据趋势。

    3 年前
  • npm 包 sky-pull 的使用教程

    什么是 sky-pull? sky-pull 是一个基于 React 开发的下拉刷新组件,可以在移动端应用中轻松实现下拉刷新功能,提高用户体验。同时,sky-pull 也提供丰富的自定义配置属性,方便...

    3 年前
  • npm 包 alfresco-uploader 使用教程

    简介 Alfresco 是一款企业级的内容管理系统(ECM),用于管理企业的所有文档、记录以及其他内容。alfresco-uploader 是 Alfresco 提供的 npm 包,用于将文件上传到 ...

    3 年前
  • npm 包 arraybuffer-utils 使用教程

    前言 随着 Web 技术的发展,前端开发变得越来越重要。作为一名前端开发者,你可能经常要处理二进制数据,在对二进制数据的处理过程中,你可能会遇到一些不方便,难以操作的问题。

    3 年前
  • npm包 mail-function 使用教程

    在前端开发过程中,邮件是一个非常重要的通信方式,不仅可以用于发送验证码、重置密码等功能,还可以用于向用户推广优惠等。在这篇文章中,我们介绍一个非常实用的npm包 mail-function,它可以帮助...

    3 年前

相关推荐

    暂无文章