Создание затухающего изображения в JavaScript путем изменения непрозрачности в течение определенного периода времени

Я новичок в JavaScript. Я действительно заинтригован, чтобы найти простую технику для изменения непрозрачности изображения, лежащего поверх другого изображения, чтобы постепенно показать это нижнее изображение. Я хочу сделать это, исчезнув. Другими словами, вычитая из свойства style.opacity постепенно, каждую секунду проходит со временем.

Я придумал следующее, но это, похоже, не работает для меня.

Текущее состояние моего кода изменяет непрозрачность внезапно меняется с 1 на негативы (-0,1, -0,2, -0,3 и т. Д.). Который в основном делает переход от верхнего изображения сразу к раскрытию нижнего.

Я хочу постепенно переходить от непрозрачности 1 к (0,9, 0,8, 0,7 и т. Д.) По мере прохождения каждой секунды.

Я хочу сделать это в чистом JavaScript. Я нашел нечто подобное в CSS, но я не хочу использовать этот подход.

Я предполагаю что (var currentOp = document.getElementById('guitar2').style.opacity;) обрабатывает переменную currentOp как строку. Из-за этого я попробовал комбинацию синтаксического анализа, чтобы плавать, делая вычитание и изменяя обратно на строку, устанавливая непрозрачность постепенно с течением времени, чтобы ничего не получилось.

<!DOCTYPE>
<html>
<head>
    <style>
    #guitar1
    {
        position: relative;
        top: 0;
        left: 0;
    }

    #guitar2
    {
        position: absolute;
        top: 0px;
        left: 0px;
        opacity: 1;
    }
    </style>
</head>
<body onload="runTime()">
    <script>

        var timer;

        function reduceOpacity()
        {
            var op = document.getElementById('guitar2');
            var currentOp = document.getElementById('guitar2').style.opacity;
            //currentOp = (parseFloat(currentOp) -  0.1).toString();
            currentOp -= 0.1;
            op.style.opacity = currentOp;
        }

        function runTime() 
        {
            timer = setInterval(reduceOpacity, 1000);
        }

    </script>
    <h4 id="header">Gibson Les Paul</h4>
    <div style="position: relative; left: 0; top: 0;">
        <img src="gibson1.png" id="guitar1" width="500" />
        <img src="gibson2.png" id="guitar2" width="500" />
    </div>
    <button type="button" onclick='document.getElementById("header").innerHTML = "yea"'>Click Me!</button>
</body>
</html>

2 ответа

Решение

Использование getComputedStyle а также getPropertyValue получить точное представление стиля элемента при загрузке.

style.property имеет привычку не обновляться, иногда необъяснимым образом извлекает значения по умолчанию, и многие значения не могут быть получены до тех пор, пока они не будут установлены. если ты console.log(op.style.opacity) в исходном примере вы увидите, что он вытягивает пустую строку, а затем начинает отсчет после переноса ее в 0.

Затем вы используете clearInterval чтобы остановить непрерывную работу функции после этой точки.

    //get the style value with getComputedStyle, which is an accurate representation of 
    //all element styling on load.
    var currentOp = getComputedStyle(op).getPropertyValue("opacity");
    // clear the interval if opacity is less than or equal to 0
    if(currentOp <= 0) clearInterval(timer);

    console.log(currentOp);

<!DOCTYPE>
<html>
<head>
    <style>
    #guitar1
    {
        position: relative;
        top: 0;
        left: 0;
    }

    #guitar2
    {
        position: absolute;
        top: 0px;
        left: 0px;
        opacity: 1;
    }
    </style>
</head>
<body onload="runTime()">
    <script>

        var timer;

        function reduceOpacity()
        {
            var op = document.getElementById('guitar2');
            
            //get the style value with getComputedStyle, which is an accurate representation of 
            //all element styling on load.
            var currentOp = getComputedStyle(op).getPropertyValue("opacity");
            // clear the interval if opacity is less than or equal to 0
            if(currentOp <= 0) clearInterval(timer);
            
            console.log(currentOp);
            //currentOp = (parseFloat(currentOp) -  0.1).toString();
            currentOp -= 0.1;
            op.style.opacity = currentOp;
        }

        function runTime() 
        {
            timer = setInterval(reduceOpacity, 1000);
        }

    </script>
    <h4 id="header">Gibson Les Paul</h4>
    <div style="position: relative; left: 0; top: 0;">
        <img src="gibson1.png" id="guitar1" width="500" />
        <img src="" id="guitar2" width="500" />
    </div>
    <button type="button" onclick='document.getElementById("header").innerHTML = "yea"'>Click Me!</button>
</body>
</html>

Примечание: мне пришлось заменить ваше изображение, так как это локальный файл.


У меня есть альтернатива, если ваше сердце не настроено на JavaScript. Animate.css - это невероятная таблица стилей, которая будет делать то же самое намного проще. (Плюс это чистый CSS, намного лучше и более равномерная поддержка)

Импортируйте это в голову

<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.7.0/animate.min.css" />

Тогда вот ваш соответствующий код:

   <div style="position: relative; left: 0; top: 0;">
    <img src="gibson1.png" id="guitar1"  width="500" />
    <img src="gibson2.png" id="guitar2" class="animated fadeOut delay-5s" style="animation-duration: 3s;" width="500" />
</div>

Может быть не совсем тот ответ, который вы ищете, но сделать это намного проще, чем анимацию JS + JQ.

Всего наилучшего!

Другие вопросы по тегам