Bootstrap每天必学之媒体对象


Posted in Javascript onNovember 30, 2015

在Web页面或者说移动页面制作中,常常看到这样的效果,左边居左(或居右),内容居右(或居左)排列,如下图所示:

Bootstrap每天必学之媒体对象

我们常常把这样的效果称为媒体对象。可以说他是一种抽像的样式,可以用来构建不同类型的组件。这些组件都具有开篇所说的样式风格。那么在Bootstrap框架中特意将些部分提取出来做来一个组件介绍。其对应的版本文件:

☑ LESS版本:对应的源文件是media.less

☑ Sass版本:对应的源文件是_media.scss

☑ 编译后版本:对应bootstrap.css文件第4792行~第4819行

1、媒体对象?默认媒体对象

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

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

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

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

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

如下图所示:

Bootstrap每天必学之媒体对象

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

在具体使用中如下所示:

<div class="media">
 <a class="pull-left" href="#">
  <img class="media-object" src="imgs/1.jpg" alt="...">
 </a>
 <div class="media-body">
  <h4 class="media-heading">系列:十天精通CSS3</h4>
  <div>全方位深刻详解CSS3模块知识,经典案例分析,代码同步调试,让网页穿上绚丽装备!</div>
 </div>
</div>

运行效果如下:

Bootstrap每天必学之媒体对象

原理分析:

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

/bootstrap.css文件第4792行~4815行/

.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 > .pull-left {
 margin-right: 10px;
}
.media > .pull-right {
 margin-left: 10px;
}

2、媒体对象?媒体对象的嵌套

在评论系统中,常常能看到下图的效果:

Bootstrap每天必学之媒体对象

从外往里看,这里有三个媒体对象,只不过是一个嵌套在另一个的里面。那么在Bootstrap框架中的媒体对象也具备这样的功能,只需要将另一个媒体对象结构放置在媒体对象的主体内“media-body”,如下所示:

<div class="media">
 <a class="pull-left" href="#">
  <img class="media-object" src="…" alt="...">
 </a>
 <div class="media-body">
  <h4 class="media-heading">Media Heading</h4>
  <div>…</div>
  <div class="media">
   <a class="pull-left" href="#">
    <img class="media-object" src="…" alt="...">
   </a>
   <div class="media-body">
    <h4 class="media-heading">Media Heading</h4>
    <div>…</div>
    <div class="media">
     <a class="pull-left" href="#">
      <img class="media-object" src="…" alt="...">
     </a>
     <div class="media-body">
      <h4 class="media-heading">Media Heading</h4>
      <div>...</div>
     </div>
    </div>
   </div>
  </div>
 </div>
</div>

在确保你的结构没有嵌套错的情况下,能直接看到下图这样的效果:

Bootstrap每天必学之媒体对象

3、媒体对象?媒体对象列表

媒体对象的嵌套仅是媒体对象中一个简单应用效果之一,在很多时候,我们还会碰到一个列表,每个列表项都和媒体对象长得差不多,同样用评论系统来说事:

Bootstrap每天必学之媒体对象

使用方法:

针对上图的媒体对象列表效果,Bootstrap框架提供了一个列表展示的效果,在写结构的时候可以使用ul,并且在ul上添加类名“media-list”,而在li上使用“media”,示例代码如下:

<ul class="media-list">
 <li class="media">
  <a class="pull-left" href="#">
   <img class="media-object" src=" " alt="...">
  </a>
  <div class="media-body">
   <h4 class="media-heading">Media Header</h4>
   <div>…</div>
  </div>
 </li>
 <li class="media">…</li>
 <li class="media">…</li>
</ul>

运行效果如下:

Bootstrap每天必学之媒体对象

原理分析:

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

/bootstrap.css文件第4816行~第4819行/

.media-list {
 padding-left: 0;
 list-style: none;
}

如果大家还想深入学习,可以点击这里进行学习,再为大家附两个精彩的专题:Bootstrap学习教程 Bootstrap实战教程

以上就是本文的全部内容,帮助大家学习Bootstrap媒体对象,希望对大家的学习有所帮助。

Javascript 相关文章推荐
鼠标图片振动代码
Jul 06 Javascript
js中scrollHeight,scrollWidth,scrollLeft,scrolltop等差别介绍
May 16 Javascript
jQuery实现渐变下拉菜单的简单方法
Mar 11 Javascript
AngularJS指令与控制器之间的交互功能示例
Dec 14 Javascript
详解vue-cli项目中用json-sever搭建mock服务器
Nov 02 Javascript
js使用swiper实现层叠轮播效果实例代码
Dec 12 Javascript
three.js实现炫酷的全景3D重力感应
Dec 30 Javascript
微信小程序渲染性能调优小结
Jul 30 Javascript
JavaScript switch语句使用方法简介
Dec 30 Javascript
JS 图片压缩原理与实现方法详解
Apr 29 Javascript
详解Node.js使用token进行认证的简单示例
May 25 Javascript
vue+vant 上传图片需要注意的地方
Jan 03 Vue.js
javascript针对cookie的基本操作实例详解
Nov 30 #Javascript
javascript闭包(Closure)用法实例简析
Nov 30 #Javascript
详解JavaScript的流程控制语句
Nov 30 #Javascript
详解JavaScript的表达式与运算符
Nov 30 #Javascript
Bootstrap每天必学之进度条
Nov 30 #Javascript
javascript省市区三级联动下拉框菜单实例演示
Nov 29 #Javascript
jQuery插件EasyUI校验规则 validatebox验证框
Nov 29 #Javascript
You might like
php中禁止单个IP与ip段访问的代码小结
2012/07/04 PHP
php内核解析:PHP中的哈希表
2014/01/30 PHP
PHP中创建图像并绘制文字的例子
2014/11/19 PHP
利用php_imagick实现复古效果的方法
2016/10/18 PHP
JAVASCRIPT IE 与 FF中兼容问题小结
2009/02/18 Javascript
javascript 同时在IE和FireFox获取KeyCode的代码
2010/02/07 Javascript
JQuery 获取json数据$.getJSON方法的实例代码
2013/08/02 Javascript
js倒计时小程序
2013/11/05 Javascript
原生js和jquery中有关透明度设置的相关问题
2014/01/08 Javascript
js 判断浏览器使用的语言示例代码
2014/03/22 Javascript
javascript对JSON数据排序的3个例子
2014/04/12 Javascript
JavaScript数值数组排序示例分享
2014/05/27 Javascript
javascript实现简单的页面右下角提示信息框
2015/07/31 Javascript
jQuery+PHP+MySQL二级联动下拉菜单实例讲解
2015/10/27 Javascript
简单讲解AngularJS的Routing路由的定义与使用
2016/03/05 Javascript
js实现不提示直接关闭网页窗口
2017/03/30 Javascript
Node.js 使用递归实现遍历文件夹中所有文件
2017/09/18 Javascript
ReactNative之FlatList的具体使用方法
2017/11/29 Javascript
vue实现验证码输入框组件
2017/12/14 Javascript
promise和co搭配生成器函数方式解决js代码异步流程的比较
2018/05/25 Javascript
vue-cli 使用vue-bus来全局控制的实例讲解
2018/09/15 Javascript
keep-Alive搭配vue-router实现缓存页面效果的示例代码
2020/06/24 Javascript
浅谈JavaScript中等号、双等号、 三等号的区别
2020/08/06 Javascript
pygame学习笔记(1):矩形、圆型画图实例
2015/04/15 Python
Python实现XML文件解析的示例代码
2018/02/05 Python
Python实现判断一行代码是否为注释的方法
2018/05/23 Python
Django后台获取前端post上传的文件方法
2018/05/28 Python
pycharm创建一个python包方法图解
2019/04/10 Python
python控制nao机器人身体动作实例详解
2019/04/29 Python
python库matplotlib绘制坐标图
2019/10/18 Python
amazeui 验证按钮扩展的实现
2020/08/21 HTML / CSS
幼儿教师思想汇报
2014/01/10 职场文书
KTV门卫岗位职责
2014/10/09 职场文书
2014年医德医风工作总结
2014/11/13 职场文书
明确岗位职责
2015/02/14 职场文书
婚庆司仪开场白
2015/05/29 职场文书