How do I get rid of the space between <img> elements in a row in a html page?
I'm displaying 3 <img> in a row like this:
<div style="width: 950px">
                <img src='/UploadedImages/86.jpg' alt='' style="width: 300px; margin: 0px; pad开发者_开发技巧ding: 0px; border: 1px solid Black" />
                <img src='/UploadedImages/85.jpg' alt='' style="width: 300px; margin: 0px; padding: 0px; border: 1px solid Black" />
                <img src='/UploadedImages/84.gif' alt='' style="width: 300px; margin: 0px; padding: 0px; border: 1px solid Black" />
        </div>
As you can see I have thin black borders around the images. My problem is that there are white spaces about 5px wide between the borders of neighbouring images and I have set the margin to be 0px but it does not work. So what is happening here?
You have to remove the whitespaces (linebreaks & spaces) between the tags:
<img src='/UploadedImages/86.jpg' alt='' style="..." /><img src='/UploadedImages/85.jpg' alt='' style="..." />
or make comments to keep linebreaks:
<img src='/UploadedImages/86.jpg' alt='' style="..." /><!--
--><img src='/UploadedImages/85.jpg' alt='' style="..." />
An img is an inline element (sort of...) so spaces and new-lines are displayed in your div. To avoid that you can float the images but then you would have to add an overflow to the container as well:
div {
  overflow: hidden;
}
div img {
  float: left;
}
The overflow on the container is needed so that the container encapsulates the images. Otherwise it will collapse.
You can get rid of the gaps by setting the font-size on the container to zero ;
CSS
.imgContainer { 
    font-size: 0px ; 
    white-space: nowrap; 
}
HTML
<div class="imgContainer">
    <img src="img1.png" />
    <img src="img2.png" />
    <img src="img3.png" />
</div>
Wrap images in an ul and float the li:
<div style="width: 950px">
 <ul>
  <li><img src='/UploadedImages/86.jpg' alt='' /></li>
  <li><img src='/UploadedImages/85.jpg' alt='' /></li>
  <li><img src='/UploadedImages/84.jpg' alt='' /></li>
 </ul>
</div>
and then we add display:block; to img css:
 ul li {
 float:left;
 display:inline;
 list-style:none;
 }
 ul li img {
 border: 1px solid #000;
 display:block;
 padding: 0;
 width: 300px;
 }
jFiddle demo
 
         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论