Ошибка типа: не удается прочитать свойства undefined (чтение «длины») при использовании vue-lottie

#vue.js #lottie

Вопрос:

Я пытаюсь заставить анимацию Lottie работать с Vue с помощью vue-lottie, и я следую примеру кода, используемого в репозитории, но когда я пытаюсь запустить код, я вижу следующую ошибку в консоли:

введите описание изображения здесь

 [Vue warn]: Error in mounted hook: "TypeError: Cannot read properties of undefined (reading 'length')"

found in

---> <Lottie> at node_modules/vue-lottie/src/lottie.vue
       <VSheet>
         <TheThreeColumnLayOut> at src/components/TheThreeColumnLayout.vue
           <Dashboard> at src/views/Dashboard.vue
             <VMain>
               <VApp>
                 <App> at src/App.vue
                   <Root>

TypeError: Cannot read properties of undefined (reading 'length')
    at completeLayers (lottie.js?94f1:1579)
    at Object.completeData (lottie.js?94f1:1968)
    at workerStart (lottie.js?94f1:2071)
    at Object.postMessage (lottie.js?94f1:1545)
    at Object.completeAnimation (lottie.js?94f1:2147)
    at AnimationItem.setupAnimation (lottie.js?94f1:12992)
    at AnimationItem.setParams (lottie.js?94f1:12970)
    at Object.loadAnimation (lottie.js?94f1:12711)
    at Object.loadAnimation (lottie.js?94f1:16474)
    at VueComponent.mounted (lottie.vue?d421:30)

 

Ответ №1:

После долгих поисков в Google я нашел решение, описанное здесь:

Решение:

Вместо того, чтобы импортировать данные анимации, подобные этому (как показано в примере):

import * as animationData from '../path/to/the/animationData.json'

…вместо этого импортируйте его следующим образом:

import animationData from '../path/to/the/animationData.json'


Итак, минимальный рабочий пример использования vue-lottie в вашем собственном коде будет выглядеть так:

 <template>
  <div>
    <Lottie :options="animationOptions" />
  </div>
</template>

<script>
import Lottie from 'vue-lottie/src/lottie.vue'
import animationData from '../path/to/your/animation.json'
export default {
  components: {
    Lottie
  },
  data: function () {
    return {
      animationOptions: {
        animationData: animationData
      }
    }
  }
}
</script>