เมนูแบบเลื่อนได้พร้อม Bootstrap - เมนูขยายคอนเทนเนอร์เมื่อไม่ควร


138

ฉันลองวิธีนี้ ( ซอของพวกเขา ) เพื่อเปิดใช้งานเมนูแบบเลื่อนได้ด้วย Bootstrap แต่ด้วยวิธีการนี้เมนูแบบเลื่อนได้จะขยายคอนเทนเนอร์ - ซอ - เมนูที่ไม่สามารถเลื่อนได้อย่างถูกต้องไม่ทำเช่นนี้

ฉันจะแก้ไขสิ่งนี้ได้อย่างไร ข้อเสนอแนะเกี่ยวกับวิธีการอื่น ๆ ที่เข้ากันได้กับ Bootstrap ก็มีค่าเช่นกัน!


สำหรับการอ้างอิงนี่คือ HTML จากซอของวิธีแรก:

<ul class="nav">
    <li class="dropdown">
        <a class="icon-key icon-white" data-toggle="dropdown" href="#" style=
        "font-weight: bold"></a>

        <div class="dropdown-menu" style="margin-left: 2em">
            <ul class="dropdown-menu">
                <!-- static non-scrollable menu header 1 -->
            </ul>
        </div>

        <div class="dropdown-menu" style="margin-left: 2em">
            <ul class="dropdown-menu">
                <li class="disabled">
                    <a href="#"><i class="icon-group"></i> <b>My Groups</b></a>
                </li>

                <li>
                    <div class="dropdown-menu scroll-menu scroll-menu-2x"
                    style="margin-left: 2em">
                        <ul class="dropdown-menu scroll-menu scroll-menu-2x">
                            <li>
                                <a href="#">User</a>
                            </li>

                            <li>
                                <a href="#">Administrators</a>
                            </li>

                            <li>
                                <a href="#">Some Other Group</a>
                            </li>
                        </ul>
                    </div>

                    <ul class="dropdown-menu scroll-menu scroll-menu-2x">
                        <!-- Additional menu items omitted for brevity -->
                    </ul>
                </li>
            </ul>
        </div>

        <div class="dropdown-menu" style="margin-left: 2em">
            <ul class="dropdown-menu">
                <!-- static non-scrollable menu header 2 -->
            </ul>
        </div>

        <div class="dropdown-menu" style="margin-left: 2em">
            <ul class="dropdown-menu">
                <li class="disabled">
                    <a href="#"><i class="icon-user"></i> <b>My Roles</b></a>
                </li>

                <li>
                    <div class="dropdown-menu scroll-menu scroll-menu-2x"
                    style="margin-left: 2em">
                        <ul class="dropdown-menu scroll-menu scroll-menu-2x">
                            <li>
                                <a href="#">Core Users</a>
                            </li>

                            <li>
                                <a href="#">Admin</a>
                            </li>

                            <li>
                                <a href="#">Some Other Role</a>
                            </li>
                        </ul>
                    </div>

                    <ul class="dropdown-menu scroll-menu scroll-menu-2x">
                        <!-- Additional menu items omitted for brevity -->
                    </ul>
                </li>
            </ul>
        </div>

        <div class="dropdown-menu" style="margin-left: 2em">
            <ul class="dropdown-menu">
                <!-- static non-scrollable menu footer -->
            </ul>
        </div>

        <ul class="dropdown-menu">
            <li class="disabled">
                <a href="#"><i class="icon-chevron-up pull-left"></i> <i class="icon-chevron-up pull-right"></i></a>
            </li>
        </ul>
    </li>
</ul>

และ CSS:

/* So we wont impact the original bootstrap menu or it's pseudo call-out
arrow the menu is wrapped in a sub dropdown-menu with a chained scroll-menu */
ul.scroll-menu {
    position:relative;
    display:inherit!important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    -moz-overflow-scrolling:touch;
    -ms-overflow-scrolling:touch;
    -o-overflow-scrolling:touch;
    overflow-scrolling:touch;
    top:0!important;
    left:0!important;
    width:100%;
    height:auto;
    max-height:500px;
    margin:0;
    border-left:none;
    border-right:none;
    -webkit-border-radius:0!important;
    -moz-border-radius:0!important;
    -ms-border-radius:0!important;
    -o-border-radius:0!important;
    border-radius:0!important;
    -webkit-box-shadow:none;
    -moz-box-shadow:none;
    -ms-box-shadow:none;
    -o-box-shadow:none;
    box-shadow:none
}

1
นอกจากนี้ยังใช้งานได้กับ Bootstrap V4
Tes3awy

คำตอบ:


357

ฉันคิดว่าคุณสามารถทำให้สิ่งนี้ง่ายขึ้นเพียงแค่เพิ่มคุณสมบัติ CSS ที่จำเป็นให้กับคลาสเมนูเลื่อนของคุณพิเศษ ..

CSS:

.scrollable-menu {
    height: auto;
    max-height: 200px;
    overflow-x: hidden;
}

HTML

       <ul class="dropdown-menu scrollable-menu" role="menu">
          <li><a href="#">Action</a></li>
          <li><a href="#">Another action</a></li>
          <li><a href="#">Something else here</a></li>
          <li><a href="#">Action</a></li>
            ..
          <li><a href="#">Action</a></li>
          <li><a href="#">Another action</a></li>
       </ul>

ตัวอย่างการทำงาน: https://www.bootply.com/86116

Bootstrap 4

อีกตัวอย่างหนึ่งสำหรับ Bootstrap 4 โดยใช้ flexbox


6
หากใครที่ชอบ Plunker มากกว่า Bootply นี่คือ: plnkr.co/edit/3VhYW1?p=preview
tanguy_k

แถบเลื่อนจะตัดข้อความบางส่วนออก ฉันสงสัยว่าวิธีที่สะอาดที่สุดคือการเพิ่มขนาดเพื่อรองรับรายการที่กว้างที่สุด
lintmouse

ถ้าฉันต้องการหัวกระดาษและท้ายกระดาษคงที่ในเมนูแบบเลื่อนลง
นวัตกรรม

15
ฉันใช้ความสูงสูงสุด: 100vh เพื่อให้ความสูง 100%
Rob Sedgwick

โซลูชันที่หรูหราและเรียบง่ายมาก +1
Gianluca Ghettini

49

คุณสามารถใช้คลาส CSS แบบเลื่อนล่วงหน้าได้ใน bootstrap 3 ภายในองค์ประกอบการขยายของ dropdown และทำงานได้ทันทีโดยไม่ต้องใช้ css ที่กำหนดเอง

 <ul class="dropdown-menu pre-scrollable">
                <li>item 1 </li>
                <li>item 2 </li>

 </ul>

13

สำหรับ CSS ฉันพบว่าความสูงสูงสุด 180 จะดีกว่าสำหรับโทรศัพท์มือถือรุ่น 320 เมื่อแสดงเบราว์เซอร์ chrome

.scrollable-menu {
    height: auto;
    max-height: 180px;
    overflow-x: hidden;
}

นอกจากนี้ในการเพิ่มแถบเลื่อนที่มองเห็นได้ CSS นี้ควรทำเคล็ดลับ:

.scrollable-menu::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 4px;        
}    
.scrollable-menu::-webkit-scrollbar-thumb {
    border-radius: 3px;
    background-color: lightgray;
    -webkit-box-shadow: 0 0 1px rgba(255,255,255,.75);        
}

การเปลี่ยนแปลงมีผลที่นี่: https://www.bootply.com/BhkCKFEELL


1

ทำทุกอย่างในอินไลน์ของแท็ก UL

<ul class="dropdown-menu scrollable-menu" role="menu" style="height: auto;max-height: 200px; overflow-x: hidden;">
                <li><a href="#">Action</a></li>
                <li><a href="#">Another action</a></li>
                <li><a href="#">Something else here</a></li>
                <li><a href="#">Action</a></li>
                ..
                <li><a href="#">Action</a></li>
                <li><a href="#">Another action</a></li>
            </ul>

1

ฉันเพิ่งแก้ไขปัญหานี้ในโครงการของฉัน -

รหัส CSS

.scroll-menu{
   min-width: 220px;
   max-height: 90vh;
   overflow: auto;
 }

รหัส HTML

<ul class="dropdown-menu scroll-menu" role="menu">
   <li><a href="#">Action</a></li>
   <li><a href="#">Another action</a></li>
   <li><a href="#">Something else here</a></li>
   <li><a href="#">Action</a></li>
   ..
   <li><a href="#">Action</a></li>
   <li><a href="#">Another action</a></li>
</ul>

0

ฉันหวังว่ารหัสนี้ใช้ได้ดีลองนี้

เพิ่มไฟล์ CSS

.scrollbar {
    height: auto;
    max-height: 180px;
    overflow-x: hidden;
}

รหัส HTML:

<div class="col-sm-2  scrollable-menu" role="menu">
    <div>
   <ul>
  <li><a class="active" href="#home">Tutorials</a></li>
  <li><a href="#news">News</a></li>
  <li><a href="#contact">Contact</a></li>
  <li><a href="#about">About</a></li>
  <li><a href="#news">News</a></li>
  <li><a href="#contact">Contact</a></li>
  <li><a href="#about">About</a></li>
  <li><a href="#news">News</a></li>
  <li><a href="#contact">Contact</a></li>
  <li><a href="#about">About</a></li>
  <li><a href="#news">News</a></li>
  <li><a href="#contact">Contact</a></li>
  <li><a href="#about">About</a></li>
  <li><a href="#news">News</a></li>
  <li><a href="#contact">Contact</a></li>
  <li><a href="#about">About</a></li>

    </ul>
   </div>
   </div>
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.