/ / Як встановити ширину фонового кольору div? - html, css

Як встановити ширину фонового кольору div? - html, css

у мене є два <div>s з однаковим кольором тла. Як встановити ширину фону?

Очікуваний результат:

введіть опис зображення тут

Ось HTML:

<div>
<span>100% width of background</span>
</div>
<div>
<span>75% width of background</span>
</div>

Що я намагався зробити за допомогою CSS:

div {
background-color: #fc0;
margin: 2px;
}
div:last-child {
background-size: 75%;
}

jsFiddle, звичайно.

Чи можливо зробити це, окрім налаштування width a div?

Відповіді:

5 за відповідь № 1

Ви можете використовувати фонові градієнти з жорсткими зупинками.

http://jsfiddle.net/isherwood/ZWrmn

div:last-child {
background: linear-gradient(left, green 0, green 75%, transparent 75%);
}

1 для відповіді № 2

Ви не можете зробити це просто background-color, але ви можете зробити це з градієнтом CSS.

background-color завжди розглядається як один звичайний колір длявесь елемент, але градієнти розглядаються як зображення, і можуть бути розміром. Ви також можете робити інші речі з градієнтами, наприклад, багатошарові градієнти, які неможливо виконати за допомогою простого background-color.


1 для відповіді № 3

Я хотів би використовувати зображення в 1px як фон щось подібне background: url(1px.png) repeat-y; потім можна встановити background-size:75%; Зображення зараз. Зробити життя простішим і менше / просто кодом.


0 для відповіді № 4

можна використовувати градієнт:

background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIxMDAlIiB5Mj0iMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzFlNTc5OSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjY5JSIgc3RvcC1jb2xvcj0iIzFlNTc5OSIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjcwJSIgc3RvcC1jb2xvcj0iIzFlNTc5OSIgc3RvcC1vcGFjaXR5PSIwIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiMxZTU3OTkiIHN0b3Atb3BhY2l0eT0iMCIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
background: -moz-linear-gradient(left,  rgba(30,87,153,1) 0%, rgba(30,87,153,1) 69%, rgba(30,87,153,0) 70%, rgba(30,87,153,0) 100%);
background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(30,87,153,1)), color-stop(69%,rgba(30,87,153,1)), color-stop(70%,rgba(30,87,153,0)), color-stop(100%,rgba(30,87,153,0)));
background: -webkit-linear-gradient(left,  rgba(30,87,153,1) 0%,rgba(30,87,153,1) 69%,rgba(30,87,153,0) 70%,rgba(30,87,153,0) 100%);
background: -o-linear-gradient(left,  rgba(30,87,153,1) 0%,rgba(30,87,153,1) 69%,rgba(30,87,153,0) 70%,rgba(30,87,153,0) 100%);
background: -ms-linear-gradient(left,  rgba(30,87,153,1) 0%,rgba(30,87,153,1) 69%,rgba(30,87,153,0) 70%,rgba(30,87,153,0) 100%);
background: linear-gradient(to right,  rgba(30,87,153,1) 0%,rgba(30,87,153,1) 69%,rgba(30,87,153,0) 70%,rgba(30,87,153,0) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#1e5799", endColorstr="#001e5799",GradientType=1 );

Генератор градієнтів CSS

jsfiddle


0 для відповіді № 5

U має змінити ваш css на:

div {
background-color: #fc0;
margin: 2px;
}
div:last-child {

background-image: -webkit-linear-gradient(left, #fc0, #fc0 75%, transparent 75%,     transparent 100%)
}