资讯专栏INFORMATION COLUMN

前端实现:Medium(一)

VishKozus / 1173人阅读

摘要:那我们来看一下这个首页的布局是如何实现的为了实现全的覆盖,第一个要做的就是设置的为,宽度的话,应为是自动全覆盖,就无需多做设置。

  

本文发表于前端观察,最新改动可访问我的博客或是相关Github Repo。

大家好,我是新人kalasoo,现在还处在“试用期”,作为一个自学出来的前端新手,能够加入前端观察实在是异常兴奋。既然要一起来维护这个关于前端的博客,我一定会努力争取我所写的内容可以追上这里文章的质量水平。作为开始,我会做一个小小的系列来分析那些有名、特别、设计感十足或是交互体验出众的网站。同时我还会认真阅读其前端代码,为大家重现那些神奇的效果是如何实现的,当然也会尽我所知引用更多的资源来丰富内容。希望这个系列可以让大家更加了解前端技术,同时也可以锻炼我自己。

我们就从Medium开始

决定第一个来做这个网站的原因很简单,那就是好看啊!由于Medium的出现严重影响改变了博客、发布平台的风格以及编辑器等前端组建的设计,我们会分多期来分析各种细节是如何实现的。我们尤整体走向局部,所以我们先从整体布局来分析:

首页布局以及大背景图

网站背景

Medium是由Twitter的联合创始人:Evan Williams和Biz Stone创办于2012年8月创办的一个文章写作、阅读平台。注意,我这里并没有用很多网站上援引的博客平台是因为Medium的出现塑造了一种新的社会化自我营销渠道。在首页引入的Welcome to Medium里,我们看到它的初衷是为了让人们更好地写作,但是作为Twitter的一个延伸,它依旧搭载在一个社交性很强的平台之上。这也让在Medium中写作的人更愿意去分享、营销、推广自己的写作内容,甚至成为一些知名Developers, Designers and even Managers的发布渠道。例如:Facebook的Product Design Director Julie Zhuo就曾经通过在Medium上发表文章来解释Facebook为何revert掉在视觉层面上非常突出的新版界面。而更让人觉得特别的是,每当我看到好的文章分享到twitter上时,都会有作者亲自来favorite你的tweet,这简直就是自我运营啊,有木有!

好啦,闲话说完,我们进入主题。

首页布局

大背景图或是视频,已经成为累当今服务性网站设计的一个趋势,随着网速越来越快、屏幕越来越大,一张巨幅首页图片无论从视觉冲击力还是从性能上都已经不再是不可能实现的功能。那我们来看一下这个首页的布局是如何实现的:

HTML:

::before
::before
...
...
::after

CSS:

为了实现全window的覆盖,第一个要做的就是设置html, bodyheight为100%,宽度的话,应为是自动全覆盖,就无需多做设置。.container只是作为一个过度,同样设置到100%的高度(这里我会暂时忽略除了layout之外的属性设置)。
再深一层是便是.surface,除了再次继承了满高度、满宽度外,还定义了box-sizing: border-box;,请移位MDN来理解。这里要注意它加了.suface:before, .surface:after的属性,是为了自动生成clearfix的效果来阻止float溢出,但其实在这个首页之中并没有用到。

html, body, .container {
  height: 100%;
}
.surface {...}
.surface:before, .surface:after {
  display: table;
  content: " ";
}
.surface:after {
  clear: both;
}

在往里面的几个.screen-content, .surface-content只是继续控制高度,和一些默认背景颜色。直到下面这一层才定义了覆盖整个背景大图的属性,而具体的背景图片是只额姐加到了DOM的这个div里面(我想原因应该是有一些数据binding在里面,这样好做更新):

.image-fill, {
  background-position: center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}
.image-fill {
  background-color: rgba(0, 0, 0, 0.9);
}
.promo-fill {
  background-color: #000;
}
大背景图

在这里,为了实现图片可以满背景覆盖,最主要的一个元素就是background-size: cover;,这个属性一共有以下几个可能的值:

background-size:  |  | auto | cover | contain;

它们分别代表的意思是:

background-size: 50% | 120px | auto; 设置了背景图片的宽度,高度则自动计算。默认的auto维持了背景图原有的大小。

background-size: 50% auto; 同时强制定义了宽度和高度。

background-size: auto, auto, [...]; 定义给多个背景图片(注意被一个定义会用逗号隔开,与auto auto并不是一个意思)。

background-size: cover; 这样定义的背景图片会被修改图片大小(长宽比例不变),以确保刚刚好覆盖整个Element。

background-size: contain; 背景图片会被修改大小(长宽比例不变),以确保刚刚好被这个Element包裹在里面。

下面几张图分别展示了集中不同的情况:

background-size设置为cover时,即使屏幕被拉窄拉宽,图片依旧很好地覆盖着整个屏幕(更多的比对还可以访问MDN):

contain时,图片长宽比并不发生变化,却会被包在window里面:

50% 100%时,图片长宽比按照设置的数值被拉伸:

注意,这里的背景图片都是按照默认的会重复铺排在x和y轴上,所以当背景图不能覆盖element的时候,便会出现重复的样式。此外,background-position: center;也定义了图片按照所属element的中心位置来调整大小。

兼容性

这样图片全页面覆盖的实现方法就说明完了,contain & cover属性的兼容性如下:

Chrome 3.0+

Firefox 3.6 (1.9.2)+

IE 9.0+

Opera 10.0+

Safari 4.1+

如果为了实现同样的效果,却要面对恐怖的IE7/8,肿么破,请尝试如下:

.background-cover {
  filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(
          src="PATH_TO_BACKGROUND_IMAGE",
          sizingMethod="scale");
  -ms-filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(
              src="PATH_TO_BACKGROUND_IMAGE",
              sizingMethod="scale");
}

但是要小心,这个实现方法会使得起内部的链接点击失效(请给我大MS 32个赞),而且这个实现的是background-size: 100% 100%的效果。或者可以通过jQuery (jquery.backgroundSize.js)来实现。

其他示例

这里面是一些好看的大图覆盖的例子,但是并不是所有的页面都是通过background-size来实现的:

http://www.whitmansnyc.com/

https://chrome.google.com/webstore/detail/momentum/laookkfknpbbblfpciffpaejjkokdgca?hl=en

http://quinntonharris.strikingly.com/

其实现方式其实是背景图很大,大小设置为auto,而覆盖效果则是通过设置外面一层的div大小来实现的。

http://www.lattrapereve.fr/

背景视频大小是根据window大小的变化,用javascript来修改的。

下期预告

下一期,我们会深入探讨Medium上的侧边推进栏sidebar的实现,而这个推进效果其实有好多种不一样的方法,有的可以在mobile上实现滑动效果,有的会有更好地兼容性。敬请大家期待。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/87586.html

相关文章

  • 70道前端LeetCode题目集合及视频讲解(持续更新中...)

    前端LeetCode刷题 下面是已刷的题目的目录。GitHub:https://github.com/cunzaizhuy...每日打卡更新中,欢迎关注。 数组类 26 删除排序数组中的重复项 27 移除元素 35 搜索插入位置 66 加1 80 medium 删除排序数组中的重复项2 88 合并两个有序数组 167 两数之和II - 输入有序数组 118 杨辉三角 169 easy 求众数 1...

    mayaohua 评论0 收藏0
  • 2017-06-20 前端日报

    摘要:前端日报精选专题之跟着学节流冴羽的博客全家桶仿微信项目,支持多人在线聊天和机器人聊天腾讯前端团队社区编码的奥秘模块实现入门浅析知乎专栏前端每周清单发布新版本提升应用性能的方法中文寇可往吾亦可往用实现对决支付宝的微信企业付款到零 2017-06-20 前端日报 精选 JavaScript专题之跟着 underscore 学节流 - 冴羽的JavaScript博客 - SegmentFau...

    Galence 评论0 收藏0
  • 2017-07-08 前端日报

    摘要:前端日报精选精读与提案知乎专栏第期认识引擎记录一次利用工具进行性能优化的真实案例简书中的使用规则教程继承的实现方法个人文章中文译组件渲染性能探索个人文章周刊第期表单性能的改进实践知乎专栏简单可重用的图表库知乎专栏 2017-07-08 前端日报 精选 精读 TC39 与 ECMAScript 提案 - 知乎专栏【第989期】认识 V8 引擎记录一次利用 Timeline/Perform...

    王岩威 评论0 收藏0
  • 2017-06-13 前端日报

    摘要:前端日报点关注,不迷路精选前端团队工作流迁移记译新语法私有属性知乎专栏前端每周清单大前端技术生命周期模型发布面向生产环境的前端性能优化模块实现入门浅析知乎专栏中文一个线下沙龙中国最大的前端技术社区单页面博客从前端到后端基于 2017-06-13 前端日报 点关注,不迷路:-P 精选 ESLint v4.0.0 released - ESLint - Pluggable JavaScri...

    曹金海 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<