琴& 2019-01-16 20:03 采纳率: 50%
浏览 498
已采纳

为什么设置透明度的功能并没有实现?

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        #div1 {
            width: 100px;
            height: 100px;
            background: red;
            filter: alpha(opacity=30);
            opacity: 0.3;
        }
    </style>
    <script>
        window.onload = function () {
            var oDiv = document.getElementById('div');
            var i = 0;

            oDiv.timer = null;

            oDiv.onmouseover = function () {
                startMove(oDiv, 'opacity', 100)
            }
            oDiv.onmouseout = function () {
                startMove(oDiv, 'opacity', 30)
            }
        }

        function getStyle(obj, attr) {
            if (obj.currentStyle) {
                return obj.currentStyle[attr];
            } else {
                return getComputedStyle(obj, false)[attr];
            }
        }

        function startMove(obj, attr, iTarget) {
            clearInterval(obj.timer);
            obj.timer = setInterval(function () {
                var iCur = 0;

                if (atrr == 'opacity') {
                    iCur == parseInt(parseFloat(getStyle(obj, attr)) * 100);
                } else {
                    iCur == parseInt(getStyle(obj, attr));
                }
                var iSpeed = (iTarget - iCur) / 8;
                iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);

                if (iCur == iTarget) {
                    clearInterval(obj.timer);
                } else {
                    if (attr == 'opacity') {
                        obj.style.filter = 'alpha(opacity=' + (iCur + iSpeed) + ')'; //优先级
                        obj.style.opacity = (iCur + iSpeed) / 100;
                    } else {
                        obj.style[attr] = iCur + iSpeed + 'px';
                    }
                }
            }, 30)
        }
    </script>
</head>

<body>
    <div id="div1"></div>
</body>

</html>
  • 写回答

2条回答 默认 最新

  • 天际的海浪 2019-01-16 20:54
    关注

    写代码不认真,又不懂看浏览器错误信息

            window.onload = function () {
                var oDiv = document.getElementById('div1');//-----------少 1
                var i = 0;
    
                oDiv.timer = null;
    
                oDiv.onmouseover = function () {
                    startMove(oDiv, 'opacity', 100)
                }
                oDiv.onmouseout = function () {
                    startMove(oDiv, 'opacity', 30)
                }
            }
    
            function getStyle(obj, attr) {
                if (obj.currentStyle) {
                    return obj.currentStyle[attr];
                } else {
                    return getComputedStyle(obj, false)[attr];
                }
            }
    
            function startMove(obj, attr, iTarget) {
                clearInterval(obj.timer);
                obj.timer = setInterval(function () {
                    var iCur = 0;
    
                    if (attr == 'opacity') {//---------------你写成 atrr
                        iCur = parseInt(parseFloat(getStyle(obj, attr)) * 100);//---------------赋值是一个 =
                    } else {
                        iCur = parseInt(getStyle(obj, attr));//--------------------赋值是一个 =
                    }
                    var iSpeed = (iTarget - iCur) / 8;
                    iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);
    
                    if (iCur == iTarget) {
                        clearInterval(obj.timer);
                    } else {
                        if (attr == 'opacity') {
                            obj.style.filter = 'alpha(opacity=' + (iCur + iSpeed) + ')'; //优先级
                            obj.style.opacity = (iCur + iSpeed) / 100;
                        } else {
                            obj.style[attr] = iCur + iSpeed + 'px';
                        }
                    }
                }, 30)
            }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大