@jKEeY

В чём проблема на удалённом сервере?

В проекте использую lottie-web
animation components
<template lang="pug">
    .bs-loading-card.d-flex
        lottie(:options='defaultOptions', :height='125', :width='125', v-on:animCreated='handleAnimation')
</template>

<script>

    import Lottie from './lottie';
    import animationData from '../../assets/loading-brick.json';

    export default {
        name: "loadinganim",
        components: {
            'lottie': Lottie
        },
        data() {
            return {
                defaultOptions: { default: animationData },
                animationSpeed: 2
            }
        },
        methods: {
            handleAnimation: function (anim) {
                console.log(this.defaultOptions)
                this.anim = anim;
            },

            stop: function () {
                this.anim.stop();
            },

            play: function () {
                this.anim.play();
            },

            pause: function () {
                this.anim.pause();
            },

            onSpeedChange: function () {
                this.anim.setSpeed(this.animationSpeed);
            }
        },
    }
</script>


Lottie component
<template>
    <div :style="style" ref="lavContainer"></div>
</template>

<script>
    import lottie from 'lottie-web';
    import * as animationData from '../../assets/loading-brick.json';

    export default {
        props: {
            options: {
                type: Object,
                required: true
            },
            height: Number,
            width: Number,
        },

        data () {
            return {
                style: {
                    width: this.width ? `${this.width}px` : '100%',
                    height: this.height ? `${this.height}px` : '100%',
                    overflow: 'hidden',
                    margin: '0 auto'
                }
            }
        },

        mounted () {
            console.log(this.options)
            this.anim = lottie.loadAnimation({
                    container: this.$refs.lavContainer,
                    renderer: 'svg',
                    loop: this.options.loop !== false,
                    autoplay: this.options.autoplay !== false,
                    animationData: this.options.default,
                    rendererSettings: this.options.rendererSettings
                }
            );
            this.$emit('animCreated', this.anim)
        }
    }
</script>


на локалке всё отрабатывает хорошо, но когда выгружаю в prod, то при старте анимации в компоненте lottie выдаёт ошибку
Cannot set property a of function(){return e} which has only a getter vue js
  • Вопрос задан
  • 104 просмотра
Пригласить эксперта
Ответы на вопрос 1
добавь объект anim в data() {}
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
28 нояб. 2024, в 05:21
2000 руб./за проект
28 нояб. 2024, в 05:18
500 руб./за проект
28 нояб. 2024, в 03:51
3500 руб./за проект