2016-04-14 4 views
2

Я создал веб-сайт с двумя белыми виджетами боковой панели, серой коробкой и некоторыми цветными кнопками. В настоящее время элементы виджета и круга позиционируются с использованием атрибута CSS left:175px; для #mw-panel, между тем #right-navigation li a размещается с использованием right: 30em;.CSS: настройка контейнеров Div с использованием поля

К сожалению, это только выглядит лучше всего на моем конкретном экране 1080p. Если окно браузера изменено, элементы виджета и кнопки начинают перекрывать основную статью.

Я попытался превратить left: 175px; в margin-right: 20px;, так что виджеты сохраняют постоянное расстояние 20px между изделием. Попробовав это, мои белые виджеты попали в левый край окна моего браузера. Затем я попытался изменить отображение: absolute; к чему-то другому, но я был не понятен.

Что мне нужно изменить в моем коде, чтобы получить тот же результат, что и на картинке?

enter image description here

#right-navigation li a { 
 
font-size: 14px; 
 
color: white; 
 
text-shadow: 4px 4px 15px #000; 
 
display: block; 
 
padding-left: 60px; 
 
opacity: 0; 
 
-webkit-transition: all .4s cubic-bezier(.4, 0, .2, 2); 
 
transition: all .4s cubic-bezier(.4, 0, .2, 2); 
 
    width: 250px; 
 
} 
 

 
#right-navigation li, #right-navigation li:after { 
 
    -webkit-transition: all .2s cubic-bezier(.4, 0, .2, 1); 
 
    transition: all .2s cubic-bezier(.4, 0, .2, 1); 
 
} 
 

 
#right-navigation li:after { 
 
content:''; 
 
width: 10px; 
 
height: 10px; 
 
border-radius: 50%; 
 
left: 20px; 
 
top: 20px; 
 
} 
 

 

 
#right-navigation li:hover:after { 
 
width: 50px; 
 
height: 50px; 
 
left: 0; 
 
top: 0; 
 
} 
 

 
#right-navigation li:hover > li { 
 
transform: rotate(90deg); 
 
} 
 

 
#right-navigation li:hover a { 
 
    opacity: 1; 
 
    padding-left: 75px; 
 
} 
 

 
#right-navigation li{ 
 
border-radius: 50%; 
 
margin-top: 10px; 
 
width: 50px; 
 
height: 50px; 
 
box-shadow: 0 0 4px rgba(0, 0, 0, .11), 0 4px 8px rgba(0, 0, 0, .22); 
 
transition: 0.2s opacity; 
 
} 
 

 
#left-navigation { 
 
position: absolute; 
 
} 
 

 
#right-navigation{ 
 
position:absolute; 
 
right: 30em; 
 
top: 250px; 
 
} 
 

 
.content .entry { 
 
    background-color: #6b6b6b; 
 
} 
 

 
#mw-panel,#p-personal { 
 
padding: 1em; 
 
background: #fff; 
 
border-radius: 10px; 
 
position: absolute; 
 
left: 175px; 
 
width: 240px; 
 
} 
 

 
#ca-view{ 
 
top: 120px; 
 
background:url('') no-repeat center,radial-gradient(#00FFFF, #00878E);} 
 

 
#ca-ve-edit{ 
 
top: 180px; 
 
background:url('') no-repeat center, radial-gradient(yellow, #BD9D01); 
 
} 
 

 
#ca-edit,#ca-viewsource{ 
 
top: 240px; 
 
background:url('') no-repeat center, radial-gradient(orange, #B75D00); 
 
} 
 

 
.site-inner, 
 
.wrap{margin:0 auto;max-width:1200px;} 
 

 
.site-inner{clear:both;padding-top:40px;} 
 

 

 
body { 
 
    background-image: linear-gradient(#434343, #282828); 
 
    color: #555; 
 
    font-family: Open Sans, sans-serif; 
 
    font-size: 14px; 
 
    line-height: 24px; 
 
    margin: 0; 
 
}
<body class="full-width-content"> 
 

 
    <link rel="stylesheet" id="child-theme-css" href="https://vocaloid.de/wp-content/themes/Vuturize/style.css" type="text/css" media="all"> 
 
    <div id="mw-panel"> 
 

 
    <div class="portal" role="navigation" id='p-navigation' aria-labelledby='p-navigation-label'> 
 
     <h3 id='p-navigation-label'>Box1</h3> 
 
     TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST 
 
    </div> 
 
    </div> 
 

 
    <div class="site-inner"> 
 
    <div class="content-sidebar-wrap"> 
 

 
     <main class="content"> 
 
     <article id="content" class="page type-page entry"> 
 
      <h1>Demo</h1> 
 
      <div id="bodyContent" class="mw-body-content"> 
 
      <div id="jump-to-nav" class="mw-jump"> 
 
       <a href="#mw-head">Navigation</a> 
 
      </div> 
 
      </div> 
 
     </article> 
 
     </main> 
 
    </div> 
 

 
    <div id="mw-head"> 
 
     <div id="p-personal" role="navigation" class="" aria-labelledby="p-personal-label"> 
 
     <h3 id="p-personal-label">Box2</h3> 
 
     TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST TEST</div> 
 

 
     <div id="right-navigation"> 
 
     <div id="p-views" role="navigation" class="vectorTabs" aria-labelledby="p-views-label"> 
 
      <h3 id="p-views-label">Ansichten</h3> 
 
      <ul> 
 
      <li id="ca-view" class="selected"> 
 
      </li> 
 
      <li id="ca-ve-edit"> 
 
      </li> 
 
      </ul> 
 
     </div> 
 
     </div> 
 
    </div> 
 
    </div>

+0

Пожалуйста, предоставьте остальную часть своего CSS и сделайте скрипку/codepen. Самый простой способ помочь кому бы то ни было - это повторить проблему. – theblindprophet

+0

@theblindprophet В настоящее время внедрен полный CSS-код.Сознательно, я не добавлял CSS. Если бы у меня было, вам пришлось бы переопределить код. Осмотр элемента может сработать, по моему мнению .. Или это из-за решения проблем другим? Ну, я это исправлю. –

ответ

0

добавить этот класс .Выходные-внутренний контейнер для выравнивания центра экрана.

.site-inner{ 
 
    margin-left: auto; 
 
    margin-right: auto; 
 
}

+0

Я применил ваши аннотации к правильному классу, но, похоже, это не сработало. Я попытался добавить мои упомянутые атрибуты «margin», но мне не удалось сделать разрыв в 20 пикселей между виджетами и статьей. –

0

Вместо того чтобы использовать конкретные размеры px пикселов, а использовать % или em размеров.
Вы также можете задать селектор запросов CSS @media, чтобы установить основу для размера em, установив body{font-size:**px} (где * - число, основанное на доле текущего размера отображения/окна).

Это заложит основу вашего адаптивного макета, и ваше содержимое будет масштабироваться соответствующим образом.

Если вам нужно решение с высокой степенью масштабируемости, попробуйте создать свой контент в SVG, и у элемента SVG есть min-width и min-height свойства в корневом элементе SVG, что предотвратит слишком малое количество вещей.

Вот пример SVG объяснения:

<svg 
    xmlns="http://www.w3.org/2000/svg" 
    version="1.1" 
    width="100%" 
    height="100%" 
    viewBox="0 0 1920 1080" 
    style="display:block; min-width:640px; min-height:360px"> 

    ... The rest of your code here ... 

</svg> 

выше будет очень хорошо масштабируется, как вы можете видеть, разрешение в зависимости от текущего разрешения, но масштабирует отлично и сохранить пропорции на меньшие (или больше) разрешения/мониторы.

Единственный недостаток заключается в том, что вам придется делать все в SVG, что не так уж плохо, но может быть проблемой, если в этом случае указано иное.
Преимущества отличные, потому что вы можете создавать свои интерактивные компоненты с помощью SVG-редактора, например, «Inkscape» (бесплатно), а затем сохранять и просматривать свои макеты в веб-браузере, который грубо экономит много время в отличие от кодирования все от руки.

+0

Благодарим вас за предложение. Сделать отзывчивым может быть вариант, о котором я должен думать позже, но сначала я должен получить прибыль. Я также думаю, что использование% или em не будет правильным решением моей проблемы. Даже если бы я применил ваши рекомендации, они будут работать только для «нет», а не «легально». Надеюсь, вы заметили, что заметили различие обоих: в настоящее время он проверяет левый и правый края, но вместо этого он должен проверить контейнер .site-inner div и сделать разрыв в 20 пикселей –

Смежные вопросы