div“顶部” bug IE 和其他一切。大问题

发布于 2024-08-29 17:29:38 字数 992 浏览 9 评论 0原文

我是 CSS 新手,所以请帮助我解决这个问题。我希望能够正确地描述它。

我正在我的网站内容所在的位置制作名为 content 的 div。我用 z-index:-1; 做了它所以一个图像要放在这个 div 上。但在 Chrome、FF 和 Safari 中,内容变得不活跃。我无法选择文本、单击链接并在表格中写入。所以我尝试在 z-index 中使用正状态,但 IE 不知道这意味着什么。该死。所以我决定制作条件div。这是代码:

.content
{
    background:#FFF;
    width:990px;
    position:relative;
    float:left;
    top:50px;
}
.content_IE
{
    background:#FFF;
    width:990px;
    position:relative;
    float:left;
    top: 50px;
    z-index:-1;
}

这是 HTML:

<!--[if IE 7]>
    <div class="content_IE" style="height:750px;">
        <![endif]-->
            <div class="content" style="height:550px;">

z-index 一切都很好,但问题是,如果 .content 类中没有 top,一切在 IE 中看起来都很好,但在其他浏览器中没有空格。如果我放回顶部:50px; .content_IE 类中还有其他 50px 的填充。我的意思是,该页面看起来像是我放置了 top:50px;和 padding-top=50px;。我已经尝试了像 margin-top:-50px; 这样的一切顶部填充:-50px;诸如此类的事情,但我仍然在圈子里。仅当 .content 类中没有 top 选项时,它看起来才正常。请帮忙。

I am new in CSS so please help me in this problem. I hope to describe it wright.

I am making div named content where my site content is. I made it with z-index:-1; so an image to be over this div. But in Chrome, FF and safari, content became inactive. I cant select text , click on link and write in the forms. So I tried with positive states in the z-index but IE don't know what this means. Damn. So I decided to make conditional div. Here is the code:

.content
{
    background:#FFF;
    width:990px;
    position:relative;
    float:left;
    top:50px;
}
.content_IE
{
    background:#FFF;
    width:990px;
    position:relative;
    float:left;
    top: 50px;
    z-index:-1;
}

and here is the HTML:

<!--[if IE 7]>
    <div class="content_IE" style="height:750px;">
        <![endif]-->
            <div class="content" style="height:550px;">

Everything is fine with the z-index but the problem is that if there is no top in .content class everything looks fine in IE but there is no space in the other browsers. If i put back the top:50px; there onother 50px like padding in the .content_IE class. I mean that the page looks like I've put top:50px; and padding-top=50px;. I've try everything like margin-top:-50px; padding-top:-50px; and stuff like this but I am still in the circle. It look fine only if there is no top option in .content class. Please help.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

┊风居住的梦幻卍 2024-09-05 17:29:38

问题在于,这两个 div 并不相互排斥 - IE 会同时看到您的 .content 和 .content_IE div,并且您尝试设置的位置由 Interior 控制。 content div(因为两者都应用了 position:relative)。尝试从代码中删除 .content div 并在 IE 中查看它,您可能会看到在其他浏览器中遇到的相同问题。 (有关更多信息,这篇文章很好地介绍了定位)

(这是也许有点冗长,但它提供了一些合理的策略来防止将来出现此类问题):

这里发生了一些事情:IE 特定的处理和 z-index 问题。

首先,一些样式/策略建议:

  1. 不要使用内联样式(您在 .content 和 .content_IE 类上设置的高度),这更没有意义,因为您通过设置其他样式属性(如宽度) CSS。我认为这样做的唯一原因(即使如此,我仍然建议反对它)是如果你正在使用 Javascript 做一些事情。
  2. 对于特定于 IE 的声明,更好的方法是设置样式,以便您可以处理级联 - 在 .content 类上设置基本样式(高度、宽度等),然后应用IE 的具体规则很少(例如不同的高度)。它看起来像这样:

    <前><代码><样式>
    。内容 {
    背景:#fff;
    高度:550px;
    宽度:990px​​;
    位置:相对;
    浮动:向左;
    顶部:50 像素;
    }

这样你应该会体验到 a) 更少的潜在怪异,以及 b) 更容易维护你的代码。如果您的样式表足够大,请将规则分成两部分(例如“main.css”和“ie7.css”),然后从条件注释内部链接到 IE 规则。

现在,就 z-index 而言问题是 - 我建议在您尝试放置在内容“顶部”的图像上应用 z-index,并使用正值,这应该可以防止我认为您在 IE 中看到的一些情况。 (IE 通常会出现负值问题,因此如果可以的话请尽量避免)

The problem is that the two divs aren't mutually exclusive - IE's seeing both of your .content and .content_IE divs, and the positioning that you're trying to set is being governed by the interior .content div (because both have position: relative applied to them). Try removing the .content div from your code and look at it in IE, you'll likely see the same issues you're having in the other browsers. (For more information, this article covers positioning pretty well)

(this is perhaps a bit verbose, but it provides some reasonable strategies for preventing this sort of issue in the future):

There are a few things going on here: IE-specific handling, and z-index issues.

First, a few style/strategy recommendations:

  1. Don't use inline styles (the height you're setting on the .content and .content_IE classes), this makes even less sense since you're setting other style properties (like width) through the CSS. The only reason I can see for doing this (and even then I'd still recommend against it) is if you're doing something with Javascript.
  2. For the IE-specific declarations, a better approach is to set up your styles so that you can take care of the Cascade - set the base styles (height, width, etc) on the .content class, and then apply a few IE specific rules (like the different height). It would look something like this:

    <style>
        .content {
            background: #fff;
            height: 550px;
            width: 990px;
            position: relative;
            float: left;
            top: 50px;
        }
    </style>
    <!--[if IE 7]>
    <style>
        .content {
            height: 750px;
        }
    </style>
    <![endif]-->
    

That way you should experience a) less potential weirdness, and b) an easier time maintaining your code. If your stylesheets are large enough, break up the rules in to two (like "main.css" and "ie7.css", and link to the IE one from inside of the conditional comment.

Now, as far as the z-index issue goes - I would recommend applying the z-index on the image that you're trying to place 'on top' of the content, and use a positive value. This should prevent some of what I believe you're seeing happen in IE (IE tends to have issues with negative values in general, so try to avoid them if you can).

If that fixes the problem, keep working with your code so that you don't need the conditional CSS, too.

長街聽風 2024-09-05 17:29:38

IE z-index 有几个错误,但您所描述的听起来不像其中之一,您一定在做一些奇怪的事情。你能举个例子吗?我这么问是因为如果可以的话我会尽量避免使用这样的条件。

但这是您简短而甜蜜的答案:

.content
{
  background:#FFF;
  width:990px;
  position:relative;
  float:left;
  top:50px;
  *top: 0px;
}

基本上,我们有条件地将 IE 的 .content top 设置为 0px。

There are couple of bugs with IE z-index, but what you are describing does not sound like one of them, you must be doing something odd. Can you show an example? I ask because I would try to avoid using conditionals like this if I can.

But here is your short and sweet answer:

.content
{
  background:#FFF;
  width:990px;
  position:relative;
  float:left;
  top:50px;
  *top: 0px;
}

Basically, we are conditionally setting the .content top to 0px for IE.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文