一个纠结的CSS问题

2011-07-01 17:54:54 +08:00
 liyandong
<style>
p{
margin:0 auto;
width:600px;
text-indent:2em;
}
p img{
padding:5px;
margin-left:-2em;
}
</style>
<p><img style="background:#ffff00;border:1px solid #ffff00;" src="http://www.baidu.com/img/baidu_sylogo1.gif" /><img style="border:1px solid #000;" src="http://www.baidu.com/img/baidu_sylogo1.gif" /><img style="background:#000;border:1px solid #000;" src="http://www.baidu.com/img/baidu_sylogo1.gif" /></a></p>


这段代码怎么能让P里面的img正常显示:首行不缩进?第二行的图片和第一行的垂直对齐?

我直接用margin-left:-2em;纠正不行。第二行还是不行的。纠结了。

这个都是因为万恶的WP的处理机制啊。

不想去掉p的text-indent:2em;属性啊。
6574 次点击
所在节点    CSS
21 条回复
zythum
2011-07-01 18:19:04 +08:00
首先,没懂你意思。其次</a>是什么情况。。上半身哪去了?
能把想要的效果说清楚下呢
liyandong
2011-07-01 18:24:34 +08:00
@zythum 那个</a>是失误了。应该没有的,呵呵

图片首行不缩进,如果这种P标签里的图片总宽度大于P的宽度,图片不是就到第二行了么?然后,我想要的效果是:第二行的图片和第一行的垂直对齐。

总体来说呢,就是P里如果是包括的文字呢,就首行缩进,是IMG呢,就不首行缩进了。纠结的问题。。
zythum
2011-07-01 18:43:10 +08:00
还是没懂。。。我理解能力不够。。。
leojoy710
2011-07-01 18:50:45 +08:00
有个很挫的办法...给img加display:block...
这个很挫很挫很挫很挫...
magicolor
2011-07-01 18:51:04 +08:00
缩进的原因就是 “text-indent:2em” 你却不想去掉,不解~~
chone
2011-07-01 18:52:34 +08:00
zythum
2011-07-01 19:23:17 +08:00
@chone @magicolor @leojoy710 block文字不是要另起一行了呢。。。。

其实朱一一直没懂意思。。你们都能看懂呢。。。还是因为我笨啊。。。呜呜呜
Emory_M
2011-07-01 22:22:13 +08:00
用:first伪类吧,缺点就是ie6不支持
leojoy710
2011-07-01 22:47:10 +08:00
@zythum 所以说是很挫的办法...因为只适用于这种特定的情况...并且会有很多副作用...

@Emory_M 好奇怎么做到...
NemoAlex
2011-07-02 00:31:04 +08:00
img标签display:block就可以了
dimlau
2011-07-02 01:28:57 +08:00
给包裹 IMG 的 P 添加单独 Class ,然后这个 Class 不缩进。
liyandong
2011-07-02 16:12:34 +08:00
纠结啊,看来不能在CSS里定义P了?副作用好怕怕。。。
liyandong
2011-07-02 16:18:14 +08:00
@NemoAlex @Emory_M @zythum @leojoy710 @magicolor 因为文字很多,也要经常插图,所以图片带来的问题很令人纠结啊。唉唉。我知道display:block可以,但是我想寻求更好的解决方法……呜呜
liyandong
2011-07-02 16:19:18 +08:00
@dimlau 不曲线救国的话可以么。呜呜~~~
liyandong
2011-07-02 16:20:48 +08:00
@Emory_M 可是我想要兼容啊
liyandong
2011-07-02 16:22:12 +08:00
@magicolor 因为文字很多,所以,每段文字都单独设置缩进很累人,而且也要经常插图,所以,想寻求更好的办法,
dimlau
2011-07-02 17:54:33 +08:00
p img:first-child{margin-left:-2em}
dimlau
2011-07-02 17:59:15 +08:00
或者:p img{float:left}

这样的话要注意给 p 清除浮动:clear:both;
Emory_M
2011-07-02 20:05:45 +08:00
@leojoy710 应该是:first-child,好长时间没用过了~
@liyandong ie6就用js吧,是时候无视ie6了
Emory_M
2011-07-02 20:06:12 +08:00
@leojoy710 应该是:first-child,好长时间没用过了~
@liyandong ie6就用js吧,是时候无视ie6了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/15201

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX