← 返回
未分类

leaflet

Build, debug, and integrate Leaflet web maps, including map setup, tile layers, markers, popups, GeoJSON overlays, bounds fitting, event handling, and plugin...
构建、调试和集成 Leaflet 网页地图,包括地图初始化、瓦片图层、标记、弹出框、GeoJSON 覆盖层、边界适配、事件处理及插件...
jvy jvy 来源
未分类 clawhub v1.0.0 1 版本 99765.8 Key: 无需
★ 0
Stars
📥 426
下载
💾 1
安装
1
版本
#latest

概述

Leaflet

Use this skill for practical 2D web map work with Leaflet.

Leaflet is best for lightweight interactive maps that need simple setup, raster or XYZ tile layers, GeoJSON overlays, and straightforward custom controls. It is usually the right choice when the user wants a dependable browser map without the heavier rendering model of WebGL-first stacks.

Workflow

  1. Confirm the runtime first:
    • plain HTML
    • Vite
    • React
    • Next.js or another SPA framework
  2. Confirm the actual map job:
    • base map only
    • markers and popups
    • GeoJSON overlay
    • choropleth or feature styling
    • draw/edit interaction
    • bug fixing or migration
  3. Start from the smallest visible map before adding controls, overlays, clustering, or plugins.
  4. Check container size and CSS before debugging data or tile logic.
  5. Keep data CRS assumptions explicit; Leaflet usually expects WGS84 longitude/latitude input for GeoJSON-style work.

Implementation Guardrails

  • Ensure the map container has a real height before initializing the map.
  • Use L.map(...) once per container and clean it up in SPA teardown paths.
  • Fit bounds from real data instead of hardcoding zoom/center when the dataset is dynamic.
  • Prefer L.geoJSON(...) for lightweight vector overlays and feature-level styling.
  • Keep tile URLs configurable and attribute them correctly.
  • Use clustering or canvas-based rendering when marker counts grow large.
  • Treat plugins as optional dependencies; verify maintenance status and compatibility before adopting them.

Common Failure Checks

  • Blank map: verify container height, CSS import, tile URL, and network access.
  • Tiles not loading: verify URL template, attribution requirements, CORS behavior, and rate limits.
  • Features in the wrong place: verify coordinate order and whether the source data is really WGS84 lon/lat.
  • Map rendering oddly after resize or tab switch: call map.invalidateSize() after the container becomes visible.
  • Memory leaks in React or SPA routes: remove the map instance and detach listeners on teardown.
  • Slow interaction with many points: cluster points, simplify GeoJSON, or switch from DOM-heavy markers to canvas-friendly rendering.

Practical Patterns

Minimal map

  • Create the map only after the container exists.
  • Add one tile layer with attribution.
  • Set a sane initial center/zoom or fit to bounds from data.

GeoJSON overlay

  • Use L.geoJSON with explicit style and onEachFeature.
  • Keep popup content deterministic and escape or sanitize user-provided text.
  • Fit to the resulting layer bounds when the overlay is the main subject.

Interactive app integration

  • Store the map instance outside repeated render loops.
  • Update layers incrementally instead of recreating the entire map on every state change.
  • Separate base layer setup from data overlay updates.

Drawing and editing

  • Use a maintained drawing plugin only when the user explicitly needs editing.
  • Confirm output format, CRS assumptions, and persistence flow before wiring edit tools.

Task Boundaries

  • Use this skill for Leaflet-specific implementation, debugging, and integration patterns.
  • For CRS and reprojection decisions, use project or wgs84.
  • For China-specific CGCS2000 reasoning, use cgcs2000.
  • For file-based GIS conversion or batch reprojection, use qgis.
  • For Mapbox GL JS or vector-tile style expressions, use mapbox.
  • For CesiumJS globe rendering, use cesium.

What To Return

  • A minimal working Leaflet setup or a targeted fix.
  • The likely root cause when debugging a broken map.
  • Clear notes on tile source assumptions, coordinate order, and CRS constraints.
  • Any required cleanup or lifecycle handling for the framework in use.
  • A smaller reproducible example first if the original integration is too noisy.

OpenClaw + ClawHub Notes

  • Keep examples generic, portable, and safe to paste into local projects.
  • Do not hardcode private tile servers, private tokens, or machine-specific paths.
  • Prefer maintained public dependencies and standards-based examples.
  • For clawhub.ai publication, keep examples reproducible and version/changelog updates semver-driven.

Reference Docs In This Skill

  • Read {baseDir}/references/patterns.md when generating or fixing Leaflet code for vanilla HTML, Vite, React, or GeoJSON-heavy pages.

版本历史

共 1 个版本

  • v1.0.0 当前
    2026-03-31 01:24 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

office-efficiency

wps

jvy
面向中国用户的WPS Office工作流:创建、编辑、审阅、转换及排查.docx/.xlsx/.pptx及WPS格式的文字/表格/演示文档。
★ 46 📥 23,752
dev-programming

Github

steipete
使用 `gh` CLI 与 GitHub 交互,通过 `gh issue`、`gh pr`、`gh run` 和 `gh api` 管理议题、PR、CI 运行及高级查询。
★ 677 📥 326,908
dev-programming

CodeConductor.ai

larsonreever
AI驱动平台,提供快速全栈开发、智能体、工作流自动化及低代码AI集成的可扩展产品创建。
★ 72 📥 181,702