0

Don't know how to describe, Please check it in codepen.

http://codepen.io/rick-li/pen/JKEbw

<div class="container">
<h1></h1>
<div class="box">
<div class="sharePanel">
  <div>content</div>
</div>
<div class="sharePanel">  
</div>
</div>
</div>


body 
{
    font: 15px / 1.8em "Microsoft YaHei";
    line - height: 40px;
}

.container {
    width: 960px;
    margin: 20px auto;
    border: solid 1px;
}

.container h1 {
    text - align: center; /*center the inline-block*/
}

.container.box {

    text - align: center;
}

.container.sharePanel {
    display: inline - block;
    height: 100px;
    width: 100px;
    border: solid 1px;
    border - radius: 5px;
    margin - right: 10px;

}


Rick Li
  • 1,457
  • 2
  • 14
  • 19
  • 1
    If you can't even describe it, how to you expect us to solve it? – takendarkk Jan 03 '14 at 06:57
  • When I add something to the second div, even an  , both divs are aligned correctly – Njol Jan 03 '14 at 06:57
  • 1
    You need `vertical-align:top`. If you want to know why, see http://stackoverflow.com/questions/12950479/display-inline-block-elements-vertical-aligns-inproperly/12950536#12950536. I am voting to close as duplicate, since this is just another vertical alignment question and none of the answers so far explain what the problem actually is. – andyb Jan 03 '14 at 06:58

4 Answers4

1

Use vertical-align: top; default vertical-align value is baseline

.container .sharePanel {
 vertical-align: top;
}
Harshit Tailor
  • 3,261
  • 6
  • 27
  • 40
1

You need to apply vertical-align:top to your div , because default property for inline elements is vertical-align:baseline

CSS:

.container .sharePanel {
 vertical-align: top;
}

Refer the below link for better understanding of your problem:

Cross-browser-inline-block

Pbk1303
  • 3,702
  • 2
  • 32
  • 47
0

Try something Like below

CSS

p{

}
body{
background: url();

  font: 15px/1.8em "Microsoft YaHei";
  line-height: 40px;

}

.container{
  width :960px;
  margin: 20px auto;
  border: solid 1px;
}

.container h1{
  text-align: center; /*center the inline-block*/
}

.container .box{

  text-align: center;
}

.container .sharePanel{
   display: inline-block;
   height: 100px;
  width: 100px;
  border: solid 1px;
  border-radius: 5px;
  margin-right: 10px;
  text-align: center;
   vertical-align: top;
}

HTML

<!-- container layout  -->
<div class="container">

  <h1></h1>
  <div class="box">
    <div class="sharePanel">
      content
    </div>
    <div class="sharePanel">

    </div>


  </div>
  <p></p>
</div>

Use vertical-align: top; ti aligh correctly. Here is Fiddle

Gopal Joshi
  • 2,350
  • 22
  • 49
0

try something like this

 <div class="sharePanel"> content </div>
 <div class="sharePanel">&nbsp; </div>

ALTERNATIVE

.container .sharePanel {
  border: 1px solid;
  border-radius: 5px;
  display: inline-block;
  height: 100px;
  margin-right: 10px;
  text-align: center;
  vertical-align: top;
  width: 100px;
}
rajesh kakawat
  • 10,826
  • 1
  • 21
  • 40