如何用Vue3和Plotly.js实现一个交互式世界地图动画

本文由ScriptEcho平台提供技术支持

项目地址:传送门

利用 Plotly.js 创建交互式世界生命预期地图

应用场景

本代码展示了如何使用 Plotly.js 创建一个交互式世界生命预期地图,允许用户按年份浏览不同国家和地区的生命预期数据。该地图可以用于研究世界各地生命预期随时间推移的变化,并识别出生命预期较低或较高的地区。

基本功能

  • 使用 Plotly.js 创建世界地图,显示各个国家和地区的生命预期数据。
  • 使用滑块和播放/暂停按钮,用户可以按年份浏览生命预期数据。
  • 地图上的颜色编码表示不同生命预期水平,并提供每个国家/地区的生命预期值。

功能实现步骤及关键代码分析

1. 加载必要库

javascript 复制代码
import Plotly from 'plotly.js-dist'
import { onMounted } from 'vue'

2. 加载 D3.js 库

javascript 复制代码
const loadJavascript = (jsUrl) => {
  return new Promise((resolve, reject) => {
    const script = document.createElement('script')
    script.type = 'text/javascript'
    script.onload = () => resolve('')
    script.onerror = (err) => reject(err)
    script.src = jsUrl
    document.body.appendChild(script)
  })
}

onMounted(async () => {
  await loadJavascript(
    'https://registry.npmmirror.com/d3/3.5.17/files/d3.min.js',
  )

3. 加载数据

javascript 复制代码
d3.csv(
    'https://raw.githubusercontent.com/plotly/datasets/master/gapminder_with_codes.csv',
    function (err, rows) {
      // ...
    },
  )

4. 创建帧和滑块步骤

javascript 复制代码
var frames = []
var slider_steps = []

var n = 11
var num = 1952
for (var i = 0; i <= n; i++) {
  // ...
  slider_steps.push({
    // ...
  })
  num = num + 5
}

5. 创建地图数据和布局

javascript 复制代码
var data = [
  {
    // ...
  },
]
var layout = {
  // ...
}

6. 创建 Plotly 图表

javascript 复制代码
Plotly.newPlot('myDiv', data, layout).then(function () {
  Plotly.addFrames('myDiv', frames)
})

总结与展望

经验与收获

  • 了解了如何使用 Plotly.js 创建交互式地图。
  • 学会了如何加载外部数据并将其可视化。
  • 理解了使用滑块和播放/暂停按钮实现动画效果。

未来拓展与优化

  • 添加更多数据源,以显示其他健康指标,如婴儿死亡率或预期寿命。

  • 允许用户根据其他标准(如人口或 GDP)过滤数据。

  • 优化地图的响应能力,使其在不同设备上都能正常显示。

    更多组件:


![id-6696b96d6465217bff3f194397c18f0a.jpg](https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/79b2ebc5f59740249e22e1b72c323afa~tplv-k3u1fbpfcp-jj-mark:0:0:0:0:q75.image#?w=701&h=393&s=38266&e=jpg&b=fdfcfc)

获取更多Echos

本文由ScriptEcho平台提供技术支持

项目地址:传送门

微信搜索ScriptEcho了解更多

相关推荐
于慨1 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶1 天前
前端交互规范(Web 端)
前端
CHU7290351 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing1 天前
Page-agent MCP结构
前端·人工智能
王霸天1 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc1 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说1 天前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js