主页 > 知识库 > CSS图文混排的几种方案

CSS图文混排的几种方案

热门标签:服务器配置 铁路电话系统 网站文章发布 智能手机 呼叫中心市场需求 美图手机 检查注册表项 银行业务
百度新闻首页的方案:
复制代码 代码如下:

table>
 tbody>
 tr>
 td class="topic-pic">a href="">img src="">/a>/td>
 td class="topic-txt">…/td>
 /tr>
 /tbody>
/table>

html结构丑陋,但css简单。
新浪微博首页的方案:
复制代码 代码如下:

div class="twit_item MIB_linedot2">
div class="twit_item_pic">
a href="" target="_blank">
img src="" ...>
/a>
/div>
div class="twit_item_content">
....
/div>
/div>

CSS:
复制代码 代码如下:

.twit_list dd .twit_item_pic{float:left;width:66px;padding-top:2px;} .twit_list dd .twit_item_content{float:left;width:316px;color:#666;line-height:18px;}

大部分应试者都是这个答案。用了浮动就必须定宽,结构就失去灵活性,同时必须解决浮动带来的一系列问题。
网易首页方案:
复制代码 代码如下:

ul>
 li class="list-figure">a href="">img src="">/a>/li>
 li>a href="">…/a>/li>
 li>a href="">…/a>/li>
 li>a href="">…/a>/li>
/ul>

CSS:
复制代码 代码如下:

 .list-figure { float: left; _display: inline; width: 130px; margin-left: -140px; margin-top: 6px; }
 

这些写法都是欠缺对css基本概念的理解。如果理解block formatting context(块级格式化上下文)的概念, 就不会这么写了。触发了BFC的块级元素,它的边缘不会和float box重叠。
推荐的方案:
复制代码 代码如下:

div class="item">
div class="pic">.../div>
div class="content">.../div>
/div>

CSS:
复制代码 代码如下:

.item .pic { float:left;margin-right:10px; }
.item .content { overflow:hidden;zoom:1; } /* 或用display:table-cell */
 


我写的一个实例
复制代码 代码如下:

!DOCTYPE html>
html lang="zh">
    head>
        meta charset="utf-8">
        meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">

        meta name="viewport" content="width=device-width">
        style type="text/css">
          body {
              margin: 0;
              padding: 1em 0;
              background-color: #f3f3f3;
              font:16px/1.7 Arial, Helvetica, sans-serif;
              color:#5a5a5a
          }
          a {
            color: #08c;
            text-decoration: none
          }
          header h1{
                text-align:center
            }
          ul{margin: 0;padding: 0}
          ul li{list-style: none;margin: 0;font-size: 13px;}
          h3{line-height: 1.7;margin: 0}
          .item .pic { float:left;margin-right:10px; }
          .item .content { overflow:hidden;zoom:1; } /* 或用display:table-cell */
        /style>
        !--[if lt IE 9]>
            script src="http://html5shiv.googlecode.com/svn/trunk/html5.js">/script>
        ![endif]-->
    /head>
    body>
    header>左图右内容的效果实现 /header>
    div class="item">
      div class="pic">

      /div>
      div class="content">
        h3>a href="">标题标题标题标题/a>/h3>
        ul>
          li>a href="">内容内容内容内容1/a>/li>
          li>a href="">内容内容内容内容2/a>/li>
          li>a href="">内容内容内容内容3/a>/li>
          li>a href="">内容内容内容内容4/a>/li>
        /ul>
      /div>
    /div>

    /body>
/html>
 

总结
用的不是技术,更多是技巧
由于在学校里没有系统的前端开发课程,导致对html/css/javascript基本概念的理解非常薄弱。大部分人的学习方式是:先看书,然后觉得书和实践离得很远就直接实践,遇到问题就去网上搜,而搜到的基本都是“技巧”性的东西。或者是跟着学校里的“牛人”学,掺着各种好的、坏的经验全盘接受。比如实现一个左图右内容的显示效果,写出html和css(见下图)。这是我的一道笔试题,看起来很简单吧。但是还没有人答出最佳答案。如果去网上看,国内那些大网站们是怎么实现的,就不能怪他们了。

标签:红河 乐山 新疆 河南 沧州 沈阳 长治 上海

巨人网络通讯声明:本文标题《CSS图文混排的几种方案》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266