首页 > 代码库 > Bootstrap媒体对象

Bootstrap媒体对象

前面的话

  在Web页面或者说移动页面制作中,常常看到图文混排效果,图片居左(或居右),内容居右(或居左)排列。常常把这样的效果称为媒体对象。可以说它是一种抽象的样式,可以用来构建不同类型的组件。本文将详细介绍Bootstrap媒体对象

 

默认样式

  媒体对象一般是成组出现,而一组媒体对象常常包括以下几个部分:

  ?  媒体对像的容器:常使用“media”类名表示,用来容纳媒体对象的所有内容

  ?  媒体对像的对象:常使用“media-object”表示,就是媒体对象中的对象,常常是图片

  ?  媒体对象的主体:常使用“media-body”表示,就是媒体对像中的主体内容,可以是任何元素,常常是图片侧边内容

  ?  媒体对象的标题:常使用“media-heading”表示,就是用来描述对象的一个标题,此部分可选

  除了上面四个部分之外,在Bootstrap框架中还常常使用“media-left”或者“media-right”来控制媒体对象中的对象浮动方式

  [注意]在 html 结构中, .media-right 应当放在 .media-body 的后面

  媒体对象样式相对来说比较简单,只是设置他们之间的间距

.media,.media-body {  overflow: hidden;  zoom: 1;}.media,.media .media {  margin-top: 15px;}.media:first-child {  margin-top: 0;}.media-object {  display: block;}.media-heading {  margin: 0 0 5px;}.media-left {  margin-right: 10px;}.media-right {  margin-left: 10px;}
<div class="media">    <a class="media-left" href="#">        <img class="media-object" width=100 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>好的代码像粥一样,都是用时间熬出来的</div>    </div></div>

<iframe style="width: 100%; height: 108px;" src="http://sandbox.runjs.cn/show/2ibqn72m" frameborder="0" width="320" height="240"></iframe>

 

嵌套

  在评论系统中,经常会有媒体对象嵌套的需求。在Bootstrap框架中的媒体对象也具备这样的功能,只需要将另一个媒体对象结构放置在媒体对象的主体内“media-body”

<div class="media">    <a class="media-left" href="#">        <img class="media-object" width=100 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>好的代码像粥一样,都是用时间熬出来的</div>        <div class="media">            <a class="pull-left" href="#">                <img class="media-object" src="http://via.placeholder.com/100x100" alt="...">            </a>            <div class="media-body">                <h4 class="media-heading">我是小火柴</h4>                <div>好巧啊,我也叫小火柴</div>                <div class="media">                    <a class="pull-left" href="#">                        <img class="media-object" width=100 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">                    </a>                    <div class="media-body">                        <h4 class="media-heading">小火柴的蓝色理想</h4>                        <div>是的</div>                    </div>                </div>            </div>        </div>    </div></div><div class="media">    <a class="media-left" href="#">        <img class="media-object" width=100 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>蓝色理想衰落了,前端却欣欣向荣起来</div>    </div></div>

<iframe style="width: 100%; height: 320px;" src="http://sandbox.runjs.cn/show/342uji3b" frameborder="0" width="320" height="240"></iframe>

 

对齐方式

  图片或其他媒体类型可以顶部、中部或底部对齐。默认顶部对齐。通过.media-middle或.media-bottom来设置

.media-middle {    vertical-align: middle;}.media-bottom {    vertical-align: bottom;}
<div class="media">    <a class="media-left" href="#">        <img class="media-object" width=30 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>蓝色理想衰落了,前端却欣欣向荣起来</div>    </div></div><div class="media">    <a class="media-left media-middle" href="#">        <img class="media-object" width=30 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>蓝色理想衰落了,前端却欣欣向荣起来</div>    </div></div><div class="media">    <a class="media-left media-bottom" href="#">        <img class="media-object" width=30 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>蓝色理想衰落了,前端却欣欣向荣起来</div>    </div></div>

<iframe style="width: 100%; height: 192px;" src="http://sandbox.runjs.cn/show/6lsnsd8l" frameborder="0" width="320" height="240"></iframe>

 

媒体对象列表

  媒体对象的嵌套仅是媒体对象中一个简单应用效果之一,在很多时候,我们还会碰到一个列表,每个列表项都和媒体对象长得差不多。Bootstrap框架提供了一个列表展示的效果,在写结构的时候可以使用ul,并且在ul上添加类名“media-list”,而在li上使用“media”

  媒体对象列表,在样式上也并没有做过多的特殊处理,只是把列表的左间距置0以及去掉了项目列表符号

.media-list {  padding-left: 0;  list-style: none;}
<ul class="media-list">  <li class="media">    <a class="media-left" href="#">        <img class="media-object" width=30 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>蓝色理想衰落了,前端却欣欣向荣起来</div>    </div>  </li>  <li class="media">    <a class="media-left" href="#">        <img class="media-object" width=30 src="http://sandbox.runjs.cn/uploads/rs/26/ddzmgynp/huochai.jpg" alt="...">    </a>    <div class="media-body">        <h4 class="media-heading">小火柴的蓝色理想</h4>        <div>好的代码像粥一样,都是用时间熬出来的</div>    </div>  </li>  </ul>

<iframe style="width: 100%; height: 143px;" src="http://sandbox.runjs.cn/show/2x00odpx" frameborder="0" width="320" height="240"></iframe>

 

<script type="text/javascript" src="http://files.cnblogs.com/files/xiaohuochai/contextMenu.js"></script><script type="text/javascript" src="http://files.cnblogs.com/files/xiaohuochai/catalog.js"></script>

Bootstrap媒体对象