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 相关文章推荐
js之事件冒泡和事件捕获详细介绍
Oct 28 Javascript
JavaScript DOM进阶方法
Apr 13 Javascript
详解JavaScript实现设计模式中的适配器模式的方法
May 18 Javascript
Bootstrap Table使用方法详解
Aug 01 Javascript
用jQuery实现圆点图片轮播效果
Mar 19 Javascript
Vue.js仿Metronic高级表格(二)数据渲染
Apr 19 Javascript
详解JavaScript数组过滤相同元素的5种方法
May 23 Javascript
详解Node.js 命令行程序开发教程
Jun 07 Javascript
微信小程序“摇一摇”的实例代码
Jul 20 Javascript
详解React Native顶|底部导航使用小技巧
Sep 14 Javascript
基于vue1和vue2获取dom元素的方法
Mar 17 Javascript
解决vue props 拿不到值的问题
Sep 11 Javascript
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 论坛采集程序 模拟登陆,抓取页面 实现代码
2009/07/09 PHP
PHP操作数组相关函数
2011/02/03 PHP
yii实现model添加默认值的方法(2种方法)
2016/01/06 PHP
jquery中使用$(#form).submit()重写提交表单无效原因分析及解决
2013/03/25 Javascript
HTML页面滚动时获取离页面顶部的距离2种实现方法
2013/09/05 Javascript
2种jQuery 实现刮刮卡效果
2015/02/01 Javascript
JavaScript表格常用操作方法汇总
2015/04/15 Javascript
jquery用ajax方式从后台获取json数据后如何将内容填充到下拉列表
2015/08/26 Javascript
基于jQuery实现网页打印功能
2015/12/01 Javascript
使用pcs api往免费的百度网盘上传下载文件的方法
2016/03/17 Javascript
[原创]jQuery常用的4种加载方式分析
2016/07/25 Javascript
同步文本框内容JS代码实现
2016/08/04 Javascript
webpack写jquery插件的环境配置
2017/12/21 jQuery
详解angular路由高亮之RouterLinkActive
2018/04/28 Javascript
JavaScript生成指定范围随机数和随机序列的方法
2018/05/05 Javascript
Vue 组件注册实例详解
2019/02/23 Javascript
基于JQuery和DWR实现异步数据传递
2020/10/16 jQuery
Python ldap实现登录实例代码
2016/09/30 Python
Python3之文件读写操作的实例讲解
2018/01/23 Python
使用tensorflow实现线性svm
2018/09/07 Python
详解用python实现基本的学生管理系统(文件存储版)(python3)
2019/04/25 Python
Python assert语句的简单使用示例
2019/07/28 Python
python-numpy-指数分布实例详解
2019/12/07 Python
django商品分类及商品数据建模实例详解
2020/01/03 Python
Python3+Selenium+Chrome实现自动填写WPS表单
2020/02/12 Python
Pytorch框架实现mnist手写库识别(与tensorflow对比)
2020/07/20 Python
乌克兰网上珠宝商店:GoldSoveren
2020/03/31 全球购物
更夫岗位责任制
2014/02/11 职场文书
护士岗前培训自我评鉴
2014/02/28 职场文书
消防安全承诺书
2014/05/22 职场文书
幼儿园教师节演讲稿
2014/09/03 职场文书
工作保证书怎么写
2015/02/28 职场文书
小升初自荐信范文
2015/03/05 职场文书
2016年社区“6.26”禁毒日宣传活动总结
2016/04/05 职场文书
Python加密与解密模块hashlib与hmac
2022/06/05 Python
Python TypeError: ‘float‘ object is not subscriptable错误解决
2022/12/24 Python