无法在VueJS中导入Popper.js

问题描述

我正在关注this tutorial,以了解如何在我的VueJS应用中制作弹出式窗口。 当我编译项目时,出现错误消息:

[Vue warn]: Error in data(): "TypeError: _popperjs_core__WEBPACK_IMPORTED_MODULE_0__.default is undefined"

import error

我将问题归结为BasePopover.vue组件-第一行<script>上写着import Popper from "popper.js"; 在我的应用程序中,我将其更改为import Popper from "@popperjs/core";,但错误仍然不断出现。

因此,我遵循官方的Popper.js tutorial进行简化。 我是通过npm i @popperjs/core安装的(也可以尝试使用VueCLI,如下图和npm install @popperjs/core --save所示)。

vue cli install

这是我当前的代码

<template>
  <div id="app">
    <button id="button" aria-describedby="tooltip">My button</button>
    <div id="tooltip" role="tooltip">My tooltip</div>
  </div>
</template>

<script>
//import Popper from "@popperjs/core/lib/popper";
import Popper from "@popperjs/core";
export default {
  name: "TestView",components: {
  },data() {
    
      const button = document.querySelector('#button');
      const tooltip = document.querySelector('#tooltip');

      Popper.createPopper(button,tooltip);
    
    return {
    };
  },};
</script>

<style>
#app {
  font-family: "Avenir",Helvetica,Arial,sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  padding: 350px 0;
  background-color: #C4DFD1;
}
</style>

我不知道该怎么办。任何帮助表示赞赏!

解决方法

import { createPopper } from '@popperjs/core';

export default {
name: "TestView",components: {
},data() {
return {
};
},mounted(){
  const button = document.querySelector('#button');
  const tooltip = document.querySelector('#tooltip');
  createPopper(button,tooltip);
}
};

您应该使用refs(而不是id,以避免混淆您),这将确保不发生冲突,因为您的应用可以包含多个具有相同ID的元素,例如#button。当使用Popper js之类的UI库时,请始终尝试将其代码放在已挂接的钩子中,已挂接的钩子确保您要定位的元素(例如#button)位于dom

,

我认为您应该这样做

import { createPopper } from '@popperjs/core';

而不是像上面那样

import Popper from "@popperjs/core";

参见此处:module bundlers