使进度条动态地改变容器其余部分的宽度

时间:2012-07-03 21:30:44

标签: html css

我有一个用jquery构建的音频播放器。标记和CSS相对简单,但我无法通过整个容器的宽度来改变宽度。

它设置为百分比但不表现为容器div的子项。我猜这是与绝对的位置有关,但如果我改变了,整个事情都会出错。

这是标记

<div class="container gradient">

    <div style="width:100px; overflow:hidden; display:inline-block;"><a href="" target="_blank"><img src="" class="artwork" height="100%"></a></div>
    <div class="name">

<p1><a href="" target="_blank"></a><br>
    <b></b></p1>

    </div>
    <div class="logo" style="font-size:12px; text-align:right; font-weight:bold;">


            <br><a href="" target="_blank""></a>
    <br>


    </div>
    <div class="player gradient">



        <a class="controls gradient" id="play" href="" title=""></a>



            <input type="range" id="seek" value="0" max=""/>




    </div><!-- / player -->

</div><!-- / Container-->

和css

.gradient {
border: 1px solid #C4C4C4;

background: #F2F2F2; 

}

.container {

position: absolute;
width: 100%;
height: 122px;



top: 0%;
left: 0%;

padding: 10px;



.artwork {height:100px; overflow:hidden; margin-left:auto; margin-right:auto;}

.containerLarge {
height: 427px;
}



.name {left:120px; position:absolute; top:7px}
.player {

box-sizing: border-box;
position:absolute;
width:91%;
bottom: 10px;

left:120px;



border-radius: 3px;
padding: 5px;
}

.controls {
border-radius:1em;
background-color:#0485bf;
display: block;
width: 34px;
height: 34px;
background-image: url(../player/src/images/sprite.png);
background-repeat: no-repeat;
float: left;
margin-right: 5px;


}
.controls:hover {background-color:#005b85}

#play {
background-position: 6px 5px;
}

#pause {
background-position: -32px 5px;
}


input[type="range"] {
width: 250px;
margin-top: -5px;
}

#close {
float: right;
background-position: -146px 5px;
display: none;
}

.volume {
position: absolute;
height: 100px;
width: 34px;
border: 1px solid black;
background-color: #242323;
top: -97px;
display: none;
}
input{
display:none\9!important;
}
input[type="range"] {

border: 1px solid #C4C4C4;
position: absolute;
top: 18px;
display: block;
width: 95%;
height: 15px;

-webkit-border-radius: 20px;
-moz-border-radius: 20px;
border-radius: 20px;
background-color: #DBDBDB;
left: 50px;

}

input::-webkit-slider-thumb {
-webkit-appearance: none;
width: 20px;
height: 20px;
border:1px solid #C4C4C4;

-webkit-border-radius: 10px;
border-radius: 10px;
background: #0485bf; 

}

input::-webkit-slider-thumb: hover {opacity : 0.3;filter: alpha(opacity=30)}

.logo {float:right; }

.embed {width:100%; background-color:black }

有问题的主要元素是.container,.controls,.player和输入类型范围。

1 个答案:

答案 0 :(得分:0)

很难看到标记发生了什么。哪个元素是进度条?如果某些东西绝对定位并设置为100%宽度,它将填充填充屏幕的宽度,而不是其父元素(除非它的父元素设置为position:relative)。