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判断变量是否未定义的代码
Mar 28 Javascript
JavaScript面向对象编程入门教程
Apr 16 Javascript
html5+javascript制作简易画板附图
Apr 25 Javascript
百度地图自定义控件分享
Mar 04 Javascript
javascript引用类型指针的工作方式
Apr 13 Javascript
实现placeholder效果的方案汇总
Jun 11 Javascript
Vue的路由动态重定向和导航守卫实例
Mar 17 Javascript
简述JS控制台的使用
Jul 15 Javascript
还不懂递归?读完这篇文章保证你会懂
Jul 29 Javascript
微信小程序之几种常见的弹框提示信息实现详解
Jul 11 Javascript
jquery插件开发模式实例详解
Jul 20 jQuery
vue+springboot图片上传和显示的示例代码
Feb 14 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
DEDE采集大师官方留后门的删除办法
2011/01/08 PHP
php 计划任务 检测用户连接状态
2012/03/29 PHP
关于PhpStorm设置点击编辑文件自动定位源文件的实现方式
2020/12/30 PHP
jQuery第三课 修改元素属性及内容的代码
2010/03/14 Javascript
JSON.stringify 语法实例讲解
2012/03/14 Javascript
jquery教程ajax请求json数据示例
2014/01/13 Javascript
利用浏览器全屏api实现js全屏
2014/01/16 Javascript
JS操作iframe里的dom(实例讲解)
2014/01/29 Javascript
JS实现一个列表中包含上移下移删除等功能
2014/09/24 Javascript
JS修改地址栏参数实例代码
2016/06/14 Javascript
JavaScript在控件上添加倒计时功能的实现代码
2017/07/04 Javascript
JavaScript同源策略和跨域访问实例详解
2018/04/03 Javascript
基于JS实现html中placeholder属性提示文字效果示例
2018/04/19 Javascript
json前后端数据交互相关代码
2018/09/19 Javascript
Nodejs处理异常操作示例
2018/12/25 NodeJs
微信小程序云开发修改云数据库中的数据方法
2019/05/18 Javascript
微信小程序实现上传word、txt、Excel、PPT等文件功能
2019/05/23 Javascript
简单学习5种处理Vue.js异常的方法
2019/06/17 Javascript
[43:26]完美世界DOTA2联赛PWL S2 Forest vs Rebirth 第二场 11.20
2020/11/23 DOTA
[01:19:46]DOTA2-DPC中国联赛 正赛 SAG vs DLG BO3 第一场 2月28日
2021/03/11 DOTA
python学习之面向对象【入门初级篇】
2017/01/21 Python
Python实现基本数据结构中栈的操作示例
2017/12/04 Python
Python编程实现的简单神经网络算法示例
2018/01/26 Python
python实现树形打印目录结构
2018/03/29 Python
Python数据可视化库seaborn的使用总结
2019/01/15 Python
Python 获取 datax 执行结果保存到数据库的方法
2019/07/11 Python
python 创建一维的0向量实例
2019/12/02 Python
Python基于Faker假数据构造库
2020/11/30 Python
Java基础面试题
2014/07/19 面试题
工会工作先进事迹
2014/08/18 职场文书
2014国庆节餐厅促销活动策划方案
2014/09/16 职场文书
秋季校运会广播稿100字
2014/09/18 职场文书
2014年重阳节老干部座谈会上的讲话稿
2014/09/25 职场文书
孕妇病假条怎么写
2015/08/17 职场文书
PyQt5实现多张图片显示并滚动
2021/06/11 Python
在Oracle表中进行关键词搜索的过程
2022/06/10 Oracle