css左图右内容(图文混排)的实现方法

作者:袖梨 2022-06-25

先看效果图

左图右内容的显示效果

百度新闻首页的方案:

 代码如下 复制代码

 
 
 
 
 
 

html结构丑陋,但css简单。

新浪微博首页的方案:

 代码如下 复制代码



....

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;}

大部分应试者都是这个答案。用了浮动就必须定宽,结构就失去灵活性,同时必须解决浮动带来的一系列问题。

网易首页方案:

 代码如下 复制代码

CSS:

 代码如下 复制代码

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

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

推荐的方案:

 代码如下 复制代码

...

...

CSS:

 代码如下 复制代码

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

我写的一个实例

 

 代码如下 复制代码



   
       
       
       
       
       
       
   
   

   

左图右内容的效果实现

   

     

     
     

     

       

标题标题标题标题


       
     

   

   
   

总结

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

相关文章

精彩推荐