IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> html加载地图,刷新地图 -> 正文阅读

[JavaScript知识库]html加载地图,刷新地图

网页获取地理位置信息,通过百度地图API,实现网页加载地图功能

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no, minimal-ui">
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="black" name="apple-mobile-web-app-status-bar-style">
    <meta content="telephone=no" name="format-detection">
    <meta content="email=no" name="format-detection">
    <title>获取地理位置并显示</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            font-size: 17px;
        }

        .map {
            width: 100%;
            height: 400px;
        }

        .btn-box {
            margin-top: 1em;
            width: 100%;
            height: 44px;
            display: box;
            display: -webkit-box;
            display: flex;
            display: -webkit-flex;
            -webkit-box-pack: justify;
            justify-content: space-between;
            webkit-justify-content: space-between;
            -webkit-box-align: center;
            align-items: stretch;
            webkit-align-items: stretch;
        }

        .btn {
            color: #fff;
            background-color: #007AFF;
            border-radius: 10px;
            font-size: 17px;
            text-align: center;
            padding: 10px
        }

        .tips {
            margin-top: 10px;
            text-align: center;
        }
    </style>
    <script src="http://api.map.baidu.com/api?v=1.2&ak=Ggf8yroht24x4KszoWsGV2OwtgExn8YQ"></script>
</head>

<body>
<div id="showmap" class="map">
</div>
<div class="btn-box">
    <div class="btn btn-get">
        获取位置数据
    </div>
    <div class="btn btn-show">
        展示地图标注
    </div>
</div>
<div class="tips"></div>
<script>
    //创建地图
    var map = new BMap.Map("showmap");
    var point = new BMap.Point(116.404, 39.915); //创建坐标点,天安门
    map.centerAndZoom(point, 14); //地图中心,数字用来设置缩放比例
    map.enableScrollWheelZoom(true);
    map.disableDragging(); //禁止拖拽
    setTimeout(function() {
        map.enableDragging(); //两秒后开启拖拽
        //map.enableInertialDragging();   //两秒后开启惯性拖拽
    }, 1000);
    setTimeout(function() {
        map.setZoom(8);
    }, 2000); //2秒后缩小到8级

    var currentPoint = {
        latAndLong: [116.404, 39.915],
        name: "这是默认的位置"
    };

    //获取地理位置
    document.querySelector(".btn-get").addEventListener('click', function() {
        getLocation();
    });

    document.querySelector(".btn-show").addEventListener('click', function() {
        addMarker(currentPoint.latAndLong, currentPoint.name);
    });

    function getLocation() {
        if(navigator.geolocation) {
            navigator.geolocation.getCurrentPosition(showPosition, showError);
        } else {
            alert("浏览器不支持地理定位。");
        };
    };

    function showPosition(position) {
        var lat = position.coords.latitude; //纬度
        var lng = position.coords.longitude; //经度
        console.log('纬度:' + lat + ',经度:' + lng);
        //数据操作
        currentPoint.latAndLong = (lng + ',' + lat).split(',');
        currentPoint.name = '我的位置';
        console.log(currentPoint);
        document.querySelector(".tips").innerText = currentPoint.name + '纬度:' + lat + ',经度:' + lng;
    };
    //创建标记点
    function addMarker(arr, name) {
        var pt = new BMap.Point(arr[0], arr[1]);
        var myIcon = new BMap.Icon("http://sandbox.runjs.cn/uploads/rs/269/px1iaa72/peoicon.png", new BMap.Size(30, 30)); //更换图标
        var marker = new BMap.Marker(pt, {
            icon: myIcon
        }); // 创建标注
        map.addOverlay(marker); // 将标注添加到地图中
        var label = new BMap.Label(name, {
            offset: new BMap.Size(20, -10)
        });
        marker.setLabel(label);
        marker.disableDragging();
        document.querySelector(".tips").innerText = "如所在位置为展示在当前窗口中,请拖动地图查看。";
    };

    function showError(error) {
        switch(error.code) {
            case error.PERMISSION_DENIED:
                document.querySelector(".tips").innerText = "定位失败,您已拒绝请求地理定位";
                break;
            case error.POSITION_UNAVAILABLE:
                document.querySelector(".tips").innerText = "定位失败,位置信息是不可用";
                break;
            case error.TIMEOUT:
                document.querySelector(".tips").innerText = "定位失败,请求获取用户位置超时";
                break;
            case error.UNKNOWN_ERROR:
                document.querySelector(".tips").innerText = "定位失败,定位系统失效";
                break;
        }
    };
</script>
</body>

</html>

在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-01 20:30:57  更:2022-02-01 20:32:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 15:10:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码