| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 6469 人关注过本帖
标题:利用linear-gradient不停的改变背景颜色,实现动态效果??????
只看楼主 加入收藏
真想学C
Rank: 1
等 级:新手上路
帖 子:31
专家分:0
注 册:2014-4-25
结帖率:40%
收藏
 问题点数:0 回复次数:4 
利用linear-gradient不停的改变背景颜色,实现动态效果??????
代码大致如下,循环的地方有问题,找不出来,各位大侠帮忙看看,谢谢了!对不起,没有分了。。。
程序代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
    <script>
        window.onload=function a(){          

        var setgrad1=document.getElementById("grad1");

        var i=0;
            for(i;i<=360;i++){
                setgrad1.style.background="linear-gradient('+i+'deg, red, blue)";
            }
        }
        var t=window.setTimeout("a()",500);
        window.clearTimeout(t);
    </script>
<style>
#grad2 {
    height: 100px;
    background: linear-gradient(90deg, red, blue); /* 标准的语法(必须放在最后) */
}
#grad3 {
    height: 100px;
    background: -webkit-linear-gradient(180deg, red, blue); /* Safari 5.1 - 6.0 */
    background: -o-linear-gradient(180deg, red, blue); /* Opera 11.1 - 12.0 */
    background: -moz-linear-gradient(180deg, red, blue); /* Firefox 3.6 - 15 */
    background: linear-gradient(180deg, red, blue); /* 标准的语法(必须放在最后) */
}
#grad4 {
    height: 100px;
    background: -webkit-linear-gradient(-90deg, red, blue); /* Safari 5.1 - 6.0 */
    background: -o-linear-gradient(-90deg, red, blue); /* Opera 11.1 - 12.0 */
    background: -moz-linear-gradient(-90deg, red, blue); /* Firefox 3.6 - 15 */
    background: linear-gradient(-90deg, red, blue); /* 标准的语法(必须放在最后) */
}
</style>
</head>
<body>
<h3>线性渐变 - 使用不同的角度</h3>
<div id="grad1" style="color:white;text-align:center;height: 100px;">0deg</div><br>
<div id="grad2" style="color:white;text-align:center;">90deg</div><br>
<div id="grad3" style="color:white;text-align:center;">180deg</div><br>
<div id="grad4" style="color:white;text-align:center;">-90deg</div>
<p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>
</body>
</html>

搜索更多相关主题的帖子: 动态 
2016-03-12 19:28
冰镇柠檬汁儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:北京
等 级:版主
威 望:120
帖 子:8078
专家分:6657
注 册:2005-11-7
收藏
得分:0 
setgrad1.style.background不能这么赋值

本来无一物,何处惹尘埃
It is empty at all here, Why pm 2.5 is so TMD high!
2016-03-14 22:42
linuxpluto
Rank: 4
等 级:贵宾
威 望:13
帖 子:889
专家分:23
注 册:2005-8-14
收藏
得分:0 
可是这效果,对比并修改吧。。
程序代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
</head>
<body style="margin:0;padding:0;">
<div id="grad1" style="color:white;text-align:center;height: 700px;"></div>



<script>
var i = -180, d = true;

function a() {
    var elm = document.getElementById("grad1");
    elm.style.background = "linear-gradient(" + i + "deg, red, blue)";
    elm.innerHTML=i+"deg";

    if (d) {i++;} else {i--;}
    if (i >= 180 || i <= -180) { d = !d; }
}

window.setInterval("a()", 5);
</script>
</body>
</html>

吃的比猪还差,干的比驴还累,起的比鸡还早,睡得比小姐还晚,挣得比民工还少,看起来比谁都好——苦命的人.人生短短几十年,不要给自己留下了什么遗憾,想笑就笑,想哭就哭,该爱的时候就去爱,无谓压抑自己
2016-05-06 16:13
linuxpluto
Rank: 4
等 级:贵宾
威 望:13
帖 子:889
专家分:23
注 册:2005-8-14
收藏
得分:0 
貌似你的代码就错了一个地方。。。循环变量加的时候引号用错了
另外360deg不知道有没有用或者报错不报错,我也没试。

另外即便没有任何错误你也看不到效果,因为速度太快了你只看到结果而已。。

吃的比猪还差,干的比驴还累,起的比鸡还早,睡得比小姐还晚,挣得比民工还少,看起来比谁都好——苦命的人.人生短短几十年,不要给自己留下了什么遗憾,想笑就笑,想哭就哭,该爱的时候就去爱,无谓压抑自己
2016-05-06 16:16
leeqihero
Rank: 3Rank: 3
等 级:论坛游侠
威 望:7
帖 子:122
专家分:135
注 册:2016-3-24
收藏
得分:0 
程序代码:
<html>
<head>
<meta charset="utf-8"/>
<style>
#grad2 {
height: 100px;
background: linear-gradient(90deg, red, blue); /* 标准的语法(必须放在最后) */
}
#grad3 {
height: 100px;
background: -webkit-linear-gradient(180deg, red, blue); /* Safari 5.1 - 6.0 */
background: -o-linear-gradient(180deg, red, blue); /* Opera 11.1 - 12.0 */
background: -moz-linear-gradient(180deg, red, blue); /* Firefox 3.6 - 15 */
background: linear-gradient(180deg, red, blue); /* 标准的语法(必须放在最后) */
}
#grad4 {
height: 100px;
background: -webkit-linear-gradient(-90deg, red, blue); /* Safari 5.1 - 6.0 */
background: -o-linear-gradient(-90deg, red, blue); /* Opera 11.1 - 12.0 */
background: -moz-linear-gradient(-90deg, red, blue); /* Firefox 3.6 - 15 */
background: linear-gradient(-90deg, red, blue); /* 标准的语法(必须放在最后) */
}
</style>
</head>
<body>
<h3>线性渐变 - 使用不同的角度</h3>
<div id="grad1" style="color:white;text-align:center;height: 100px;">0deg</div><br>
<div id="grad2" style="color:white;text-align:center;">90deg</div><br>
<div id="grad3" style="color:white;text-align:center;">180deg</div><br>
<div id="grad4" style="color:white;text-align:center;">-90deg</div>
<p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>
</body>
<script>
var i=0;
var setgrad1=document.getElementById("grad1");
window.onload=a();
function a(){
    setgrad1.style.background='linear-gradient('+i+'deg, red, blue)';
    i+=10;
    if(i<361) setTimeout("a()",500);
}
</script>
</html>
2016-05-07 19:26
快速回复:利用linear-gradient不停的改变背景颜色,实现动态效果??????
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.144087 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved