CSS Outside Border


Answer :

I think you've got your understanding of the two properties off a little. Border affects the outside edge of the element, making the element different in size. Outline will not change the size or position of the element (takes up no space) and goes outside the border. From your description you want to use the border property.



Look at the simple example below in your browser:





<div style="height: 100px; width: 100px; background: black; color: white; outline: thick solid #00ff00">SOME TEXT HERE</div>

<div style="height: 100px; width: 100px; background: black; color: white; border-left: thick solid #00ff00">SOME TEXT HERE</div>





Notice how the border pushes the bottom div over, but the outline doesn't move the top div and the outline actually overlaps the bottom div.



You can read more about it here:

Border

Outline



Try the outline property W3Schools - CSS Outline



Outline will not interfere with widths and lenghts of the elements/divs!



Please click the link I provided at the bottom to see working demos of the the different ways you can make borders, and inner/inline borders, even ones that do not disrupt the dimensions of the element! No need to add extra divs every time, as mentioned in another answer!



You can also combine borders with outlines, and if you like, box-shadows (also shown via link)



<head>
<style type="text/css" ref="stylesheet">
div {
width:22px;
height:22px;
outline:1px solid black;
}
</style>
</head>
<div>
outlined
</div>


Usually by default, 'border:' puts the border on the outside of the width, measurement, adding to the overall dimensions, unless you use the 'inset' value:



div {border: inset solid 1px black};


But 'outline:' is an extra border outside of the border, and of course still adds extra width/length to the element.



Hope this helps



PS: I also was inspired to make this for you : Using borders, outlines, and box-shadows



IsisCode gives you a good solution. Another one is to position border div inside parent div. Check this example http://jsfiddle.net/A2tu9/



UPD: You can also use pseudo element :after (:before), in this case HTML will not be polluted with extra markup:



.my-div {
position: relative;
padding: 4px;
...
}
.my-div:after {
content: '';
position: absolute;
top: -3px;
left: -3px;
bottom: -3px;
right: -3px;
border: 1px #888 solid;
}


Demo: http://jsfiddle.net/A2tu9/191/



Comments

Popular posts from this blog

Converting A String To Int In Groovy

"Cannot Create Cache Directory /home//.composer/cache/repo/https---packagist.org/, Or Directory Is Not Writable. Proceeding Without Cache"

Android SDK Location Should Not Contain Whitespace, As This Cause Problems With NDK Tools