栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

CSS3区域模块region相关编写示例

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

印刷媒体,例如一本杂志或一份报纸,相比网站最大的优势是完全灵活的安排页面和段落布局。例如,印刷媒体已经能够优雅地在多个列中填充内容,甚至复杂到如下面屏幕截图所示。

然而,由于Web的内容结构,试图在web上模仿类似的布局非常棘手。
为了使页面布局更加灵活到如印刷媒体一般,一个新的CSS3模块出现了——CSS3 regions。相比通常的在多个元素中放置内容,此模块允许内容流在页面的指定区域(regions)放置。

让我们看看这个模块是如何工作的。

大家在理解css region的时候,可以这么理解,我在文档中放了一个容器,这个容器装满了水。但是我想把水分到a区域 b区域 c区域,我不需要人工去“分”这个水,而是让浏览器去分配这些水到这些区域内。因此水装到哪个容器是无所谓的,分完了就不显示了,你只需要告诉区域跟大容器,区域是放水的地方,容器是取水的地方即可。
启用浏览器实验特性

此模块仍处于实验阶段,目前只在Google Chrome和ie下面支持带前缀的属性。如果您使用的是Google Chrome首先需要启用实验特性。在地址栏输入chrome:/ /flags/。设置”启用实验WebKit特性”为enabled状态。

基本用例

在这个例子中,我们将有两个类型的内容:主要内容和次要内容。区域1,2和4中我们填充主要内容,而次要内容将显示在区域3,见下图。

HTML

让我们开始写HTML结构。

CSS3区域模块是不受结构限制的,因此我们可以简单地把次要内容部分的html添加到主要内容外,正如我们上面提到的,我们将在主要内容的中部显示次要内容。

XML/HTML Code复制内容到剪贴板
  1.   
  2.     

    Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut.

      
  3.     

    labore et dolore magna aliqua

      
  4.   
  5.   
  6.   
  7.     

    Lorem ipsum dolor sit amet, consectetur ...

      
  8.   
  9.   
  10.     



      
  11.     

    Lorem ipsum dolor sit amet, consectetur ...

      
  12.   

然后,我们需要添加区域标记来标记内容流向什么区域。添加标记的区域是否高于或低于实际内容是没有什么影响的。

这里的意思是 假设有个div里面装了很多文字,你要把这些文字流向另一个div中,这个div放到哪都是无所谓的。

XML/HTML Code复制内容到剪贴板
  1. "regions cf">   
  2.     "region-1" class="region cf">   
  3.     "region-2" class="region">   
  4.     "region-3" class="region">   
  5.     "region-4" class="region cf">   
  6.   

CSS

在样式表中,我们指定区域的宽度和高度。高度是必须的,因为高度指定内容断点,否则内容不会流向其他区域。

这里的意思是高度规定这个容器能容纳多少内容,超过了则会流向其他容器。——@99

CSS Code复制内容到剪贴板
  1. .demo-wrapper #region-1,   
  2. .demo-wrapper #region-4  {   
  3.     width: 100%;   
  4.     height: 250px;   
  5. }   
  6. .demo-wrapper #region-4 {   
  7.     height: 400px;   
  8. }   
  9. .demo-wrapper #region-2,   
  10. .demo-wrapper #region-3 {   
  11.     width: 50%;   
  12.     height: 700px;   
  13.     margin-bottom: 25px;   
  14. }  

为了在区域内添加内容,我们使用新的CSS属性flow-into和flow-from。这些属性建立了内容和区域的桥梁。我们可以如下编写样式规则来使内容流向区域。

这个地方flow-into跟flow-from后面的单词是你自己定义的!比如说我想把a容器的文字流b c区域,我可以设置flow-into:a或者你能想象到的任何名称,之后用flow-from:你刚才用的名称。

CSS Code复制内容到剪贴板
  1. article {   
  2.     -webkit-flow-into: article;   
  3.     flow-into: article;   
  4. }   
  5. .demo-wrapper aside {   
  6.     -webkit-flow-into: aside;   
  7.     flow-into: aside;   
  8. }   
  9. #region-1,   
  10. #region-2,   
  11. #region-4 {   
  12.     -webkit-flow-from: article;   
  13.     flow-from: article;   
  14. }   
  15. #region-3 {   
  16.     -webkit-flow-from: aside;   
  17.     flow-from: aside;   
  18. }  

添加一些额外的css,我们将在浏览器中得到下面的结果。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/216212.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号