zoukankan      html  css  js  c++  java
  • h5 实现定位

    直接上代码,代码使用了vue相关的语法 并且引入了dialog插件 ,使用时直接调用getLocation()方法就可以了!

    // 定位
            function getLocation(){
                console.log(navigator)
                if (navigator.geolocation){
                    navigator.geolocation.getCurrentPosition(showPosition,showError);
                }
                else{
                    window.console("Geolocation is not supported by this browser.");
                    _self.$dialog.alert({
                            message: '您的设备不支持定位功能,请手动选择'
                        }).then(function(){
                            _self.$router.push('location');
                        });
                }
            }
            function showPosition(position){
                console.log("Latitude: " + position.coords.latitude +"<br />Longitude: " + position.coords.longitude);
                localStorage.setItem('position_lat',position.coords.latitude);
                localStorage.setItem('position_long',position.coords.longitude);
                var latlon = position.coords.latitude +','+position.coords.longitude;
                //baidu 
                var urlBaidu = "http://api.map.baidu.com/geocoder/v2/?ak=C93b5178d7a8ebdb830b9b557abce78b&callback=renderReverse&location="+latlon+"&output=json&pois=0"; 
                var urlGoogle = 'http://maps.google.cn/maps/api/geocode/json?latlng='+latlon+'&language=CN'; 
    
                _self.$http.jsonp(urlBaidu).then(function(res){
                    var res = JSON.parse(res.bodyText);
                    var locIso = res.result.addressComponent.country_code_iso;
                    
                    if(res.result.addressComponent.country !='China'){
                        _self.$dialog.confirm({
                            message: '根据定位,您所在的区域尚未开放服务,是否手动选择区域'
                        }).then(function(){
                            localStorage.setItem('position_loc',res.result.addressComponent.country);
                            _self.$router.push('location');
                        }).catch(function(){
                        });
                    }else{
                        localStorage.setItem('position_loc',_self.Kit.getCountryMcc(locIso));
                        _self.$router.push('home');
                    }
                },function(res){
                    console.log(res);
                })
            }
            function showError(error) {
                localStorage.removeItem('position_loc');
                switch (error.code) {
                    case error.PERMISSION_DENIED:
                            // 用于本地测试
                        _self.$dialog.alert({
                            message: '您已拒绝请求地理位置信息'
                        }).then(function(){
                            _self.$router.push('location');
                        });
                        break;
                    case error.POSITION_UNAVAILABLE:
                        _self.$dialog.alert({
                            message: '位置信息不可用,请手动选择'
                        }).then(function(){
                            _self.$router.push('location');
                        });
                        break;
                    case error.TIMEOUT:
                        _self.$dialog.alert({
                            message: '请求获取用户位置超时,请手动选择'
                        }).then(function(){
                            _self.$router.push('location');
                        });
                        break;
                    case error.UNKNOWN_ERROR:
                        _self.$dialog.alert({
                            message: '定位系统失效,请手动选择'
                        }).then(function(){
                            _self.$router.push('location');
                        });
                        break;
                }
            }
    

      

  • 相关阅读:
    什么叫开漏输出
    PIC16F877A TIMER1计数操作
    [转载]【Alientek STM32 实验2】按键输入
    STM32学习笔记1 IO口学习
    时间“四象限”法
    CLANNAD AFTER STORY 片头曲 「铭刻时间的歌」
    正则表达式测试工具
    War3窗口限定小工具发布
    利用ffmpeg转换mp4文件
    一个类似FlashGet的c#开源下载工具
  • 原文地址:https://www.cnblogs.com/xhliang/p/9467644.html
Copyright © 2011-2022 走看看