Почему эти два элемента перекрываются? CSS выпуск - PullRequest
0 голосов
/ 18 июня 2020

с трудом выясняет, почему эти два html элемента перекрываются. Ниже приведены файлы HTML и CSS для соответствующих элементов. Я просмотрел здесь множество тем, но ни одно из решений не работает. Спасибо!

main. css:

    #titlesection {
  height: auto;
  width: 100%;
  margin: auto;
  padding: 0px;
  margin-top: 25px;
  margin-bottom: 25px;
  position: absolute;
  display: block;
}

#contentdiv {
  top: 30%;
  left: 2%;
  width: 97%;
  margin: auto;
  height: 100%;
  position: absolute;
  display: block;
}

#title {
  padding-top: 50px;
  text-align: center;
  font-size: 60px;
  letter-spacing: 6px;
  display: block;
  margin-bottom: 1%;
  height: auto;
}

#titlesubheading {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 30px;
  text-align: center;
  letter-spacing: 7px;
  display: block;
  height: auto;
}

#socialmedia {
  width: 97%;
  display: block;
}

#smtable {
  width: 10%;
  float: right;
}

#aboutheader {
  width: 95%;
  margin: auto;
  margin-top: 5%;
  padding: 10px;
  font-size: 30px;
  display: block;
  position: static;
}

#about {
  width: 95%;
  margin: auto;
  margin-top: 1%;
  padding: 0px;
  height: auto;
  font-size: 20px;
  display: block;
}

#abouttext {
  width: 60%;
  height: auto;
  display: block;
  margin-left: 10px;
  min-height: 140px;
}

index. html:

<body>
    <section id="titlesection">
      <div id="title">
        Abdullah Rehmat
      </div>
      <div id="titlesubheading">
        Freelance Developer
      </div>
      <div id="socialmedia">
        <table id="smtable">
          <tbody>
            <tr>
              <td class="a">
                <a href="mailto: rehmat.dev@gmail.com">
                  <img
                    src="{{url_for('static', filename='images/email.png')}}"
                    width="33"
                    height="33"
                  />
                </a>
              </td>
              <td class="a">
                <a href="https://twitter.com/ARehmat20" target="_blank">
                  <img
                    src="{{url_for('static', filename='images/twitter0.svg')}}"
                    width="50"
                    height="50"
                  />
                </a>
              </td>
              <td class="a">
                <a href="https://github.com/10CodeDev" target="_blank">
                  <img
                    src="{{url_for('static', filename='images/github.png')}}"
                    width="30"
                    height="30"
                  />
                </a>
              </td>
            </tr>
          </tbody>
        </table>
      </div>
    </section>

    <div id="contentdiv">
      <div id="aboutheader">
        About:
      </div>

Вот изображение проблемы. Заголовок aboutheader перекрывает заголовок: image of the two elements overlapping

Ответы [ 2 ]

2 голосов
/ 18 июня 2020

Это потому, что у вас есть оба этих элемента как position: absolute;. Вы можете исправить это, удалив. Обновите свой CSS, чтобы он выглядел следующим образом:

Edit : Для вашей информации также, позиция позволяет вам перемещать элементы в определенных контекстах. position: absolute; позиционирует элемент из верхнего левого угла страницы или, если его родительский элемент имеет position: relative;, то вместо этого элемента. position: relative; перемещает что-либо из исходного положения.

Затем вы используете top, left, right или bottom, чтобы выбрать, как переместить элемент.

#titlesection {
  height: auto;
  width: 100%;
  margin: auto;
  padding: 0px;
  margin-top: 25px;
  margin-bottom: 25px;
  position: relative;
  display: block;
}

#contentdiv {
  top: 0;
  left: 0;
  width: 97%;
  margin: auto;
  height: 100%;
  position: relative;
  display: block;
}

#title {
  padding-top: 50px;
  text-align: center;
  font-size: 60px;
  letter-spacing: 6px;
  display: block;
  margin-bottom: 1%;
  height: auto;
}

#titlesubheading {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 30px;
  text-align: center;
  letter-spacing: 7px;
  display: block;
  height: auto;
}

#socialmedia {
  width: 97%;
  display: block;
}

#smtable {
  width: 10%;
  float: right;
}

#aboutheader {
  width: 95%;
  margin: auto;
  margin-top: 5%;
  padding: 10px;
  font-size: 30px;
  display: block;
  position: static;
}

#about {
  width: 95%;
  margin: auto;
  margin-top: 1%;
  padding: 0px;
  height: auto;
  font-size: 20px;
  display: block;
}

#abouttext {
  width: 60%;
  height: auto;
  display: block;
  margin-left: 10px;
  min-height: 140px;
}
1 голос
/ 18 июня 2020

Вы можете использовать свойство CSS position в сочетании со свойством z-index для наложения отдельного div поверх другого элемента div. Свойство z-index определяет порядок наложения для позиционированных элементов

...