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 相关文章推荐
jQuery中after的两种用法实例
Jul 03 Javascript
javascript 事件处理示例分享
Dec 31 Javascript
详细介绍jQuery.outerWidth() 函数具体用法
Jul 20 Javascript
javascript产生随机数方法汇总
Jan 25 Javascript
js滑动提示效果代码分享
Mar 10 Javascript
省市选择的简单实现(基于zepto.js)
Jun 21 Javascript
layer弹窗插件操作方法详解
May 19 Javascript
Vue AST源码解析第一篇
Jul 19 Javascript
jQuery实现手机号正则验证输入及自动填充空格功能
Jan 02 jQuery
vue-cli系列之vue-cli-service整体架构浅析
Jan 14 Javascript
用Vue.js方法创建模板并使用多个模板合成
Jun 28 Javascript
在VUE style中使用data中的变量的方法
Jun 19 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
简单的页面缓冲技术
2006/10/09 PHP
初学PHP的朋友 经常问的一些问题。不断更新
2011/08/11 PHP
ThinkPHP查询中的魔术方法简述
2014/06/25 PHP
php安装扩展mysqli的实现步骤及报错解决办法
2017/09/23 PHP
javascript getElementsByClassName实现代码
2010/10/11 Javascript
javascript标签在页面中的位置探讨
2013/04/11 Javascript
正则表达式中特殊符号及正则表达式的几种方法总结(replace,test,search)
2013/11/26 Javascript
javascript实现汉字转拼音代码分享
2015/04/20 Javascript
浅谈javascript的Array.prototype.slice.call
2015/08/31 Javascript
JS获取鼠标坐标位置实例分析
2016/01/20 Javascript
使用vue.js2.0 + ElementUI开发后台管理系统详细教程(二)
2017/01/21 Javascript
JavaScript表单即时验证 验证不成功不能提交
2017/08/31 Javascript
为什么我们要做三份 Webpack 配置文件
2017/09/18 Javascript
详解vue使用$http服务端收不到参数
2019/04/19 Javascript
JavaScript中关于base64的一些事
2019/05/06 Javascript
layui checkbox默认选中,获取选中值,清空所有选中项的例子
2019/09/02 Javascript
微信小程序关键字变色实现代码实例
2019/12/13 Javascript
一个简单的python程序实例(通讯录)
2013/11/29 Python
python 调用c语言函数的方法
2017/09/29 Python
对Python 2.7 pandas 中的read_excel详解
2018/05/04 Python
详解利用python+opencv识别图片中的圆形(霍夫变换)
2019/07/01 Python
Django认证系统实现的web页面实现代码
2019/08/12 Python
Python替换NumPy数组中大于某个值的所有元素实例
2020/06/08 Python
使用Keras画神经网络准确性图教程
2020/06/15 Python
Python 3.10 的首个 PEP 诞生,内置类型 zip() 迎来新特性(推荐)
2020/07/03 Python
Python 多线程C段扫描、检测 Ping扫描脚本的实现
2020/09/03 Python
使用数据结构给女朋友写个Html5走迷宫游戏
2019/11/26 HTML / CSS
BookOutlet加拿大:在网上书店购买廉价折扣图书和小说
2018/10/05 全球购物
Java中会存在内存泄漏吗,请简单描述
2016/12/22 面试题
应届生骨科医生求职信
2013/10/31 职场文书
五星级酒店餐饮部总监的标准岗位职责
2014/02/17 职场文书
文明城市标语
2014/06/16 职场文书
不同意离婚上诉状
2015/05/23 职场文书
毛主席纪念堂观后感
2015/06/17 职场文书
python中if和elif的区别介绍
2021/11/07 Python
python ConfigParser库的使用及遇到的坑
2022/02/12 Python