如何使用 vue 类组件
P粉529245050
P粉529245050 2024-02-26 12:39:59
0
1
437

<script lang="ts">
import { defineComponent, ref, nextTick, unref, onMounted } from 'vue';

import { useScript } from '/@/hooks/web/useScript';

const BAI_DU_MAP_URL = 'https://api.map.baidu.com/getscript?v=3.0&ak=xxx';
export default defineComponent({
  setup() {
    const wrapRef = ref<HTMLDivElement | null>(null);
    const { toPromise } = useScript({ src: BAI_DU_MAP_URL });

    async function initMap() {
      await toPromise();
      await nextTick();
      const wrapEl = unref(wrapRef);
      if (!wrapEl) return;
      const BMap = (window as any).BMap;
      const map = new BMap.Map(wrapEl);
      const point = new BMap.Point(116.404, 39.915);
      map.centerAndZoom(point, 15);
      map.enableScrollWheelZoom(true);
    }

    onMounted(() => {
      initMap();
    });

    return { wrapRef };
  },
})
</script>

vue 类组件

<script lang="ts">
import { ref, nextTick, unref } from 'vue'
import {Vue} from 'vue-property-decorator'
import { useScript } from '/@/hooks/web/useScript'

const BAI_DU_MAP_URL = 'https://api.map.baidu.com/getscript?v=3.0&ak=xxx';

export default class LogisticsDetail extends Vue {
  private wrapRef = ref<HTMLDivElement | null>(null)
  private toPromise = useScript({ src: BAI_DU_MAP_URL })

  async initMap() {
    await this.toPromise();
    await nextTick();
    const wrapEl = unref(this.wrapRef);
    if (!wrapEl) return;
    const BMap = (window as any).BMap;
    const map = new BMap.Map(wrapEl);
    const point = new BMap.Point(116.404, 39.915);
    map.centerAndZoom(point, 15);
    map.enableScrollWheelZoom(true);
  }

  mounted() {
    this.initMap()
  }

}
</script>

const { toPromise } = useScript({ src: BAI_DU_MAP_URL }); -->private toPromise = useScript({ src: BAI_DU_MAP_URL })

错误:

未捕获(在承诺中)类型错误:this.toPromise 不是函数

如何编写使用vue-class-component

P粉529245050
P粉529245050

全部回复(1)
P粉864872812

由于 Vue 3 中已弃用 vue-class-component,因此可以使用替代选项:vue-faceing-decorator

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板