O cliente deseja bordas de duas cores para uma aparência em relevo. Posso fazer isso em um elemento? Eu esperava evitar empilhar dois elementos DOM com bordas individuais.
Sim: Use a outline
propriedade; ele atua como uma segunda fronteira fora de sua fronteira. Cuidado, embora ele possa interagir de maneira instável com margens, preenchimentos e sombras projetadas. Em alguns navegadores, pode ser necessário usar um prefixo específico do navegador também; para ter certeza de que ele pega nele: -webkit-outline
e assim por diante (embora o WebKit em particular não exija isso).
Isso também pode ser útil no caso em que você deseja descartar o contorno de certos navegadores (como é o caso se você deseja combinar o contorno com uma sombra projetada; no WebKit o contorno está dentro da sombra; no FireFox é fora, então -moz-outline: 0
é útil para garantir que você não obtenha uma linha nodosa ao redor de sua bela sombra CSS).
.someclass {
border: 1px solid blue;
outline: 1px solid darkblue;
}
Edit: Algumas pessoas observaram que outline
não funciona bem com o IE <8. Embora isso seja verdade; apoiar o IE <8 realmente não é algo que você deveria fazer.
outline
existe desde o CSS2.
outline
é menos versátil do que border
. Em particular, W3C diz : "Nota. O contorno é o mesmo em todos os lados. Em contraste com as bordas, não há nenhuma propriedade 'contorno superior' ou 'contorno esquerdo' ." (Ênfase minha)
Isso é muito possível. É necessário apenas alguns truques de CSS!
div.border {
border: 1px solid #000;
position: relative;
}
div.border:before {
position: absolute;
display: block;
content: '';
border: 1px solid red;
height: 100%;
width: 100%;
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
}
<div class="border">Hi I have two border colors<br />I am also Fluid</div>
É isso que você está procurando?
border-radius
, tente reduzir o raio da borda interna em um pixel, isso tornará a lacuna entre as duas bordas arredondadas quase imperceptível.
bottom:1px
vez de height:100%
funcionar melhor para mim apenas para uma borda inferior :)
div.border
, descobri que adicionar uma margem negativa com as mesmas dimensões para o div.border:before
ajuda a manter tudo alinhado. Talvez haja uma maneira melhor de fazer isso? jsFiddle
Outra maneira é usar box-shadow
:
#mybox {
box-shadow:
0 0 0 1px #CCC,
0 0 0 2px #888,
0 0 0 3px #444,
0 0 0 4px #000;
-moz-box-shadow:
0 0 0 1px #CCC,
0 0 0 2px #888,
0 0 0 3px #444,
0 0 0 4px #000;
-webkit-shadow:
0 0 0 1px #CCC,
0 0 0 2px #888,
0 0 0 3px #444,
0 0 0 4px #000;
}
<div id="mybox">ABC</div>
Veja o exemplo aqui.
Você experimentou os diferentes estilos de borda disponíveis nas especificações CSS? Já existem dois estilos de borda que podem atender às suas necessidades:
border-style: ridge;
Ou
border-style: groove;
Contorno é bom, mas apenas quando você quer a borda ao redor.
Digamos que se você quiser fazer apenas na parte inferior ou superior, você pode usar
<style>
#border-top {
border-top: 1px solid #ccc;
box-shadow: inset 0 1px 0 #fff;
}
</style>
<p id="border-top">This is my content</p>
E para baixo:
<style>
#border-bottom {
border-top: 1px solid #ccc;
box-shadow: 0 1px 0 #fff;
}
</style>
<p id="border-bottom">This is my content</p>
Espero que isso ajude.
Em vez de usar contornos sem suporte e problemáticos, use
Exemplo:
HTML:
<img src="http://cdn3.thumbs.common.smcloud.net/common/8/6/s/863444wpPN.jpg/r-0,500-n-863444wpPN.jpg" alt="malkovich" />
CSS:
img {
padding: 1px;
background: yellow;
border:1px solid black;
}
TESTE (JSFiddle) :
Se por "relevo" você quer dizer duas bordas em torno uma da outra com duas cores diferentes, existe a outline
propriedade ( outline-left
, outline-right
....), mas é mal suportada na família IE (ou seja, IE6 e 7 não suportam de todo ) Se você precisar de duas bordas, um segundo elemento de invólucro seria de fato melhor.
Se você quer dizer usar duas cores na mesma borda. Use por exemplo
border-right: 1px white solid;
border-left: 1px black solid;
border-top: 1px black solid;
border-bottom: 1px white solid;
existem especial border-styles
para isso também ( ridge
, outset
e inset
), mas eles tendem a variar entre os navegadores na minha experiência.
border : black white;
que significa definir duas cores diferentes para uma borda que parece sequencialmente ao mesmo tempo.
outline
mas não funcionará bem no IE <8
Não é possível, mas você deve verificar se border-style
valores como inset
, outset
ou algum outro, alcançaram o efeito que você deseja .. ( eu duvido .. )
CSS3 tem propriedades de imagem de borda , mas eu não sei sobre o suporte de navegadores ainda (mais informações em http://www.css3.info/preview/border-image/ ) ..
Simplesmente escreva
style="border:medium double;"
para a tag html
Você poderia usar
<html>
<head>
<title>Two Colors</title>
<style type="text/css">
.two-colors {
background: none repeat scroll 0% 0% rgb(245, 245, 245); border-color: rgba(111,111,111,0.2) transparent;
padding: 4px; outline: 1px solid green;
}
</style>
<style type="text/css">
body {
padding-top: 20px;
padding-bottom: 40px;
background-color:yellow;
}
</style>
</head>
<body>
<a target="_blank" href="people.htm">
<img class="two-colors" src="people.jpg" alt="Klematis" width="213" height="120" />
</a>
</body>
</html>
Isso produz um bom efeito.
<div style="border: 1px solid gray; padding: 1px">
<div style="border: 1px solid gray">
internal stuff
</div>
</div>