• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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(见下图)。这是我的一道笔试题,看起来很简单吧。但是还没有人答出最佳答案。如果去网上看,国内那些大网站们是怎么实现的,就不能怪他们了。
    上一篇:不同版本IE使用不同css(css条件注释语句用法)
    下一篇:Css浏览器兼容的解决方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    CSS图文混排的几种方案 CSS,图文,混排,的,几种,方案,