移动端使用钉钉api进行地图定位

钉钉前端api

效果图 

注意事项:需要在钉钉app中打开,才能调用此地图,代码示范

需要后台接口,前端需要分割

<template>
  <div class="valStyle">
        <p class="left">
            <span class="verification">*</span>定位
            <span>{{atlas_name}}</span>
            <span @touchstart="atlas_location">
                <i class="cubeic-location"></i>
            </span>
        </p>
  </div>
</template>

<script>
import * as dd from "dingtalk-jsapi";
// 后台接口
import {getAuthInfo} from "@/api";
export default {
  name: "succession-list",
  props: {
    tree_val: Object,
  },
  data() {
    return {
      hand_from: {
        object_id: this.tree_val.id,
        address: "",
        lat: toString,
        lng: toString,
        hygiene: "",
        state: 1,
        note: "",
        water: "",
        user_visit: "",
        time_visit: "",
        phone_visit: "",
        cause_visit: ""
      },
      atlas_data:{},
      atlas_name:"",
    };
  },
  methods: {
    // 获取JSAPI鉴权参数
    getAuthInfoShow() {
      let _this = this;
      getAuthInfo().then(json => {
        if (json.state === "ok") {
          dd.config({
            agentId: json.data.agentId, // 必填,微应用ID
            corpId: json.data.corpId, //必填,企业ID
            timeStamp: json.data.timeStamp, // 必填,生成签名的时间戳
            nonceStr: json.data.nonceStr, // 必填,生成签名的随机串
            signature: json.data.signature, // 必填,签名
            type: 0, //选填。0表示微应用的jsapi,1表示服务窗的jsapi;不填默认为0。该参数从dingtalk.js的0.8.3版本开始支持
            jsApiList: ["device.geolocation.get", "biz.map.locate"] // 必填,需要使用的jsapi列表,注意:不要带dd。
          });
          // 获取位置
          dd.ready(function() {
            dd.device.geolocation.get({
              targetAccuracy: 200,
              coordinate: 1,
              withReGeocode: true,
              useCache: false, //默认是true,如果需要频繁获取地理位置,请设置false
              onSuccess: function(result) {
                // alert("02success: " + JSON.stringify(result))
                _this.atlas_data = result;
                _this.atlas_name = result.address.slice(6);

                _this.hand_from.address = result.address.slice(6);
                _this.hand_from.lat = result.latitude;
                _this.hand_from.lng = result.longitude;
                /* 高德坐标 result 结构
                {
                  longitude : Number,
                  latitude : Number,
                  accuracy : Number,
                  address : String,
                  province : String,
                  city : String,
                  district : String,
                  road : String,
                  netType : String,
                  operatorType : String,
                  errorMessage : String,
                  errorCode : Number,
                  isWifiEnabled : Boolean,
                  isGpsEnabled : Boolean,
                  isFromMock : Boolean,
                  provider : wifi|lbs|gps,
                  isMobileEnabled : Boolean
                }
                */
              },
              onFail: function(err) {
                // alert("02error: " + JSON.stringify(err))
              }
            });
          });
          dd.error(function(error) {
            /**
              {
                errorMessage:"错误信息",// errorMessage 信息会展示出钉钉服务端生成签名使用的参数,请和您生成签名的参数作对比,找出错误的参数
                errorCode: "错误码"
              }
            **/
            // alert('dd error: ' + JSON.stringify(error));
          });
        }
      });
    },
    // 地图调用
    atlas_location() {
      let _this = this;
      // 地图定位
      dd.biz.map.locate({
        latitude: _this.atlas_data.latitude, // 纬度,非必须
        longitude: _this.atlas_data.longitude, // 经度,非必须
        onSuccess: function(result) {
          // alert("03success: " + JSON.stringify(result))
          _this.atlas_name = result.snippet;
          _this.hand_from.address = result.snippet;
          _this.hand_from.lat = result.latitude;
          _this.hand_from.lng = result.longitude;

          /* result 结构 */
          // {
          //     province: 'xxx', // POI所在省会,可能为空
          //     provinceCode: 'xxx', // POI所在省会编码,可能为空
          //     city: 'xxx', // POI所在城市,可能为空
          //     cityCode: 'xxx', // POI所在城市,可能为空
          //     adName: 'xxx', // POI所在区名称,可能为空
          //     adCode: 'xxx', // POI所在区编码,可能为空
          //     distance: 'xxx', // POI与设备位置的距离
          //     postCode: 'xxx', // POI的邮编,可能为空
          //     snippet: 'xxx', // POI的街道地址,可能为空
          //     title: 'xxx', // POI的名称
          //     latitude: 39.903578, // POI的纬度
          //     longitude: 116.473565, // POI的经度
          // }
        },
        onFail: function(err) {
          // alert("03error: " + JSON.stringify(err))
        }
      });
    },
  },
  created() {
    this.getAuthInfoShow();
  },
};
</script>

<style lang="scss" scoped>
.verification {
  color: #e64340;
}
.cubeic-location {
    color: #1295fc;
    padding-bottom: 0.3rem;
}
</style>

 

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值