2015-12-16 5 views
-3

Я сделал дизайн с гибкой коробкой. Я разделил свой сайт на две части. Левая часть имеет ширину 75% от ширины окна, а правая сторона заполняет остальные.Фиксированный дизайн гибкой связи слишком широк

Проблема теперь, когда я помещаю текст в нужную секцию, текст выходит из моего экрана. Я размещаю прописку в правой части этого раздела, но она должна быть 26.843.170 пикселей (вы хорошо читаете) для того, чтобы быть хорошим! К большому количеству конечно ... Обратите внимание, что правая сторона имеет фиксированное положение.

Теперь мой вопрос: что я делаю неправильно? Вот мой код:

$(".draw-area, .artist-info, .draw-en-info").css("height", parseInt($(window).height()) - parseInt($("fieldset").height()) + "px");
.option-list { 
 
    width: 100%; 
 
    height: 200px; 
 
    overflow-y: auto; 
 
    border: solid 1px #A9A9A9; 
 
    margin: 10px 0; 
 
} 
 

 
.artist-info { 
 
\t background-color: lightgray; 
 
    margin: 0; 
 
    position: fixed; 
 
    top: 50px; 
 
    padding: 0 10px; 
 
    width: 25%; 
 
    /* padding-right: 26843170px; */ 
 
} 
 

 
.option-item { 
 
\t display: flex; 
 
    padding: 5px 10px; 
 
    transition: background-color 0.5s; 
 
    cursor: pointer; 
 
} 
 

 
.option-item:hover { 
 
\t background-color: #1DD75F; 
 
} 
 

 

 
.form-control { 
 
\t padding: 5px 5px; 
 
} 
 

 
#resultaatArtisten { 
 
\t display: none; 
 
} 
 

 
fieldset { 
 
\t background-color: white; 
 
    position: fixed; 
 
    width: 100%; 
 
    margin: 0; 
 
    border: 0; 
 
    padding: 0; 
 
    border-bottom: gray 2px solid; 
 
} 
 

 
fieldset > div { 
 
\t padding: 10px; 
 
} 
 

 
.draw-en-info { 
 
\t display: flex; 
 
    flex-direction: row; 
 
    flex-wrap: nowrap; 
 
    position: absolute; 
 
    top: 47.9px; 
 
    width: 100%; 
 
    z-index: -1; 
 
} 
 

 
#draw-area { 
 
\t width: 75%; 
 
    margin: 0; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> 
 
<main class="container"> 
 
\t <fieldset> 
 
\t \t <div> 
 
\t \t \t <input type="text" class="form-control" placeholder="Zoek op artisten naam" id="zoekArtist" /> 
 
\t \t \t <div class="option-list" id="resultaatArtisten"></div> 
 
\t \t <div> 
 
\t </fieldset> 
 

 
\t <div class="draw-en-info"> 
 
\t \t <section id="draw-area"></section> 
 
\t \t <section class="artist-info"> 
 
\t \t \t <p>Top nummers</p> 
 
\t \t \t <ul class="top-nummers"> 
 
       <li>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce varius, ligula non tempus aliquam, </li> 
 
      </ul> 
 
\t \t </section> 
 
\t </div> 
 
</main>

+0

Почему вы используете фиксированное позиционирование и Flexbox ... они взаимно исключают друг друга. –

+0

@Paulie_D: Я сделаю '# draw-area' прокручиваемым, но остальное нет. Но что вы должны использовать, сэр или мадам? –

+0

fyi, тег 'flex' относится к Apache Flex. Для вопросов CSS вы хотите «flexbox». – Brian

ответ

1

Я не совсем ясно, что вы пытаетесь сделать, но Flexbox может управлять большинством из этого.

Если есть некоторые требования, которые вы не указали, вам может потребоваться задать новый вопрос.

* { 
 
    box-sizing: border-box; 
 
    margin: 0; 
 
    padding: 0; 
 
    list-style-type: none; 
 
} 
 
.option-list { 
 
    width: 100%; 
 
    height: 200px; 
 
    overflow-y: auto; 
 
    border: solid 1px #A9A9A9; 
 
    margin: 10px 0; 
 
} 
 
.draw-en-info { 
 
    display: flex; 
 
} 
 
.draw-area { 
 
    background: plum; 
 
    flex: 1; 
 
} 
 
.artist-info { 
 
    background-color: lightgray; 
 
    padding: 0 10px; 
 
    flex: 0 0 25%; 
 
} 
 
.option-item { 
 
    display: flex; 
 
    padding: 5px 10px; 
 
    transition: background-color 0.5s; 
 
    cursor: pointer; 
 
} 
 
.option-item:hover { 
 
    background-color: #1DD75F; 
 
} 
 
.form-control { 
 
    padding: 5px 5px; 
 
} 
 
#resultaatArtisten { 
 
    display: none; 
 
} 
 
fieldset { 
 
    background-color: white; 
 
    //position: fixed; 
 
    width: 100%; 
 
    margin: 0; 
 
    border: 0; 
 
    padding: 0; 
 
    border-bottom: gray 2px solid; 
 
} 
 
fieldset > div { 
 
    padding: 10px; 
 
}
<main class="container"> 
 
    <fieldset> 
 
    <div> 
 
     <input type="text" class="form-control" placeholder="Zoek op artisten naam" id="zoekArtist" /> 
 
     <div class="option-list" id="resultaatArtisten"></div> 
 
     <div> 
 
    </fieldset> 
 

 
    <div class="draw-en-info"> 
 
    <section class="draw-area"></section> 
 
    <section class="artist-info"> 
 
     <p>Top nummers</p> 
 
     <ul class="top-nummers"> 
 
     <li>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed non risus. Suspendisse lectus tortor, dignissim sit amet, adipiscing nec, ultricies sed, dolor. Cras elementum ultrices diam. Maecenas ligula massa, varius a, semper congue, euismod 
 
      non, mi. Proin porttitor, orci nec nonummy molestie, enim est eleifend mi, non fermentum diam nisl sit amet erat. Duis semper. Duis arcu massa, scelerisque vitae, consequat in, pretium a, enim. Pellentesque congue. Ut in risus volutpat libero 
 
      pharetra tempor. Cras vestibulum bibendum augue. Praesent egestas leo in pede. Praesent blandit odio eu enim. Pellentesque sed dui ut augue blandit sodales. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; 
 
      Aliquam nibh. Mauris ac mauris sed pede pellentesque fermentum. Maecenas adipiscing ante non diam sodales hendrerit.Ut velit mauris, egestas sed, gravida nec, ornare ut, mi. Aenean ut orci vel massa suscipit pulvinar. Nulla sollicitudin. Fusce 
 
      varius, ligula non tempus aliquam,</li> 
 
     </ul> 
 
    </section> 
 
    </div> 
 
</main>