191.Vue3 + OpenLayers 实战:可控化版权信息(Attribution)详解与完整示例

🧩 一、效果目标

我们要实现以下效果:

  • ✅ 自定义版权内容(HTML)

  • ✅ 内置版权(右下角,可折叠)

  • ✅ 外部版权(自定义位置展示)

  • ✅ 自定义按钮样式

  • ✅ 控制是否折叠

🧠 二、为什么要关注 Attribution?

在使用 OSM、天地图、ArcGIS 等地图服务时,版权信息是必须展示的,否则可能存在法律风险。

OpenLayers 默认会帮我们处理版权信息,但:

  • ❌ 默认样式不可控

  • ❌ 位置固定(右下角)

  • ❌ UI 不符合项目设计

👉 所以我们需要:"可控化版权信息"


⚙️ 三、核心代码实现(Vue3 + Composition API)

javascript 复制代码
<!--
 * @Author: 彭麒
 * @Date: 2025/4/8
 * @Email: 1062470959@qq.com
 * @Description: 此源码版权归吉檀迦俐所有,可供学习和借鉴或商用。
 -->
<template>
  <div class="container">
    <div class="w-full flex justify-center flex-wrap">
      <div class="font-bold text-[24px]">
        vue3 + openlayers:可控化版权信息,学习Attribution各种API,示例展示
      </div>
    </div>
    <div ref="mapRef" class="map-x"></div>
    <div ref="outAttrRef"></div>
  </div>
</template>

<script setup>
import { ref, onMounted } from 'vue'
import 'ol/ol.css'

import { Map, View } from 'ol'
import Tile from 'ol/layer/Tile'
import OSM from 'ol/source/OSM'
import { Attribution, defaults as defaultControls } from 'ol/control'

// DOM引用
const mapRef = ref(null)
const outAttrRef = ref(null)

// 地图实例
let map = null

const initMap = () => {
  const copyrightInfo =
      '<a href="https://pengqi.blog.csdn.net/" target="_blank">&copy; 我的个性化版权信息</a>'

  // 内部版权控件(右下角)
  const inAttribution = new Attribution({
    collapsible: true,
    collapsed: true,
    label: 'C',
    tipLabel: '版权信息',
    collapseLabel: '>'
  })

  // 外部版权控件(自定义容器)
  const outAttribution = new Attribution({
    collapsible: false,
    target: outAttrRef.value,
    className: 'myCustomClass',
    expandClassName: 'myExpandClass'
  })

  map = new Map({
    target: mapRef.value,
    layers: [
      new Tile({
        source: new OSM({
          attributions: copyrightInfo
        })
      })
    ],
    view: new View({
      projection: 'EPSG:4326',
      center: [114.064839, 22.548857],
      zoom: 4
    }),
    controls: defaultControls({ attribution: false }).extend([
      inAttribution,
      outAttribution
    ])
  })
}

onMounted(() => {
  initMap()
})
</script>

<style scoped>
.container {
  width: 840px;
  height: 580px;
  margin: 0 auto;
  border: 1px solid #42B983;
}

.map-x {
  width: 800px;
  height: 400px;
  margin: 0 auto;
  border: 1px solid #42B983;
}

.myCustomClass {
  width: 100%;
}

.myExpandClass .ol-control button {
  background: #0000ff !important;
}
</style>

🔍 四、Attribution 核心 API 详解

1️⃣ collapsible(是否可折叠)

复制代码
collapsible: true
  • true:可以折叠(默认)

  • false:始终展开


2️⃣ collapsed(初始是否折叠)

复制代码
collapsed: true
  • true:默认收起

  • false:默认展开


3️⃣ label(折叠按钮文字)

复制代码
label: 'C'

👉 你可以改成图标、文字,比如:

  • "©"

  • "版权"

  • 自定义 SVG


4️⃣ tipLabel(鼠标提示)

复制代码
tipLabel: '版权信息'

👉 鼠标 hover 提示内容


5️⃣ collapseLabel(展开后按钮)

复制代码
collapseLabel: '>'

👉 控制"收起按钮"的内容


6️⃣ target(重点🔥)

复制代码
target: outAttrRef.value

👉 作用:

  • 把版权信息挂载到外部 DOM

  • 实现 UI 完全自定义


🎯 五、内置 vs 外置 Attribution

类型 特点
内置 默认右下角,适合快速使用
外置 完全自定义位置(推荐项目使用)

👉 本文实现了 双 Attribution 共存

复制代码
controls: defaultControls({ attribution: false }).extend([
  inAttribution,
  outAttribution
])

🎨 六、样式自定义技巧

复制代码
.myExpandClass .ol-control button {
  background: #0000ff !important;
}

你可以做到:

  • 改颜色

  • 改按钮形状

  • 改位置(absolute布局)

  • 改字体


🚀 七、进阶玩法(项目必备)

✅ 1. 动态切换版权(多底图)

复制代码
source.setAttributions('新的版权信息')

👉 用于:

  • 切换 OSM / 天地图 / 卫星图

  • 无人机影像图


✅ 2. 完全 Vue 化控制

👉 不用 OpenLayers UI,自己写:

  • 弹窗

  • tooltip

  • footer


✅ 3. 与业务结合(无人机巡检)

你可以这样用:

  • 飞行轨迹 → 显示数据来源版权

  • 不同任务 → 显示不同版权

  • 私有地图 → 加公司 logo + 声明


⚠️ 八、常见坑

❌ 1. target 为空

复制代码
target: outAttrRef.value

👉 必须在 onMounted 后使用


❌ 2. 默认 Attribution 未关闭

复制代码
defaultControls({ attribution: false })

👉 否则会出现重复版权


❌ 3. HTML 未生效

👉 attribution 支持 HTML,但要注意:

  • 字符串格式正确

  • 标签闭合


🏁 九、总结

通过本文你已经掌握:

  • ✅ Attribution 的所有核心 API

  • ✅ 内置 + 外置双模式实现

  • ✅ Vue3 Composition 写法

  • ✅ 高级 UI 控制方式

  • ✅ 项目实战扩展思路


💡 最后一句

在 WebGIS 项目里,细节决定专业度

👉 Attribution 虽小,但体现的是你对"工程规范 + 用户体验"的理解。


如果你想继续进阶👇:

👉 我可以帮你升级这套代码到:

  • 🔥 多地图源切换(天地图 / 高德 / OSM)

  • 🔥 无人机航线 + 点位展示

  • 🔥 海量点位优化(聚合 / WebGL)

  • 🔥 企业级 GIS 架构

直接说一句:"升级GIS项目版" 👍

相关推荐
奇舞精选1 小时前
用去年 github 最火的 n8n 快速实现自动化推送工具
前端·agent
奇舞精选2 小时前
实践:如何为智能体推理引入外部决策步骤
前端·agent
无限大62 小时前
AI实战02:一个万能提示词模板,搞定90%的文案/设计/分析需求
前端·后端
朝阳5812 小时前
控制 Nuxt 页面的渲染模式:客户端 vs 服务端渲染
前端·javascript
发现一只大呆瓜2 小时前
Vue-Vue2与Vue3核心差异与进化
前端·vue.js·面试
sunny_2 小时前
熬夜通宵读完 VitePlus 全部源码,我后悔没早点看
前端·前端框架·前端工程化
发现一只大呆瓜3 小时前
Vue2:数组/对象操作避坑大全
前端·vue.js·面试
发现一只大呆瓜3 小时前
Vue3:ref 与 reactive 超全对比
前端·vue.js·面试
lzksword3 小时前
C++ Builder XE OpenDialog1打开多文件并显示xls与xlsx二种格式文件
java·前端·c++