百度新闻首页的方案:
复制代码 代码如下:
<table>
<tbody>
<tr>
<td class="topic-pic"><a href=""><img src="/UploadFiles/2021-04-02/"> <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="/UploadFiles/2021-04-02/"></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="/UploadFiles/2021-04-02/"> <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="/UploadFiles/2021-04-02/html5.js"> <![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(见下图)。这是我的一道笔试题,看起来很简单吧。但是还没有人答出最佳答案。如果去网上看,国内那些大网站们是怎么实现的,就不能怪他们了。
复制代码 代码如下:
<table>
<tbody>
<tr>
<td class="topic-pic"><a href=""><img src="/UploadFiles/2021-04-02/"> <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="/UploadFiles/2021-04-02/"></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="/UploadFiles/2021-04-02/"> <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="/UploadFiles/2021-04-02/html5.js"> <![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(见下图)。这是我的一道笔试题,看起来很简单吧。但是还没有人答出最佳答案。如果去网上看,国内那些大网站们是怎么实现的,就不能怪他们了。
标签:
html,css,CSS图文混排
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“CSS图文混排的几种方案”评论...
更新动态
2024年12月27日
2024年12月27日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]