အဓိကအကြောင်းအရာသို့ ကျော်သွားပါ။ စာရွက်စာတမ်းလမ်းညွှန်မှုသို့ ကျော်သွားပါ။
Check
in English

Scrollspy

မည်သည့်လင့်ခ်သည် မြင်ကွင်းပို့တ်တွင် လက်ရှိအသုံးပြုနေကြောင်းညွှန်ပြရန်အတွက် လှိမ့်အနေအထားပေါ်အခြေခံ၍ Bootstrap လမ်းညွှန်မှု သို့မဟုတ် အုပ်စုအစိတ်အပိုင်းများကို စာရင်းပြုစုပါ။

ဘယ်လိုအလုပ်လုပ်လဲ

Scrollspy သည် anchor .active( <a>) ဒြပ်စင်များ ပေါ်ရှိ အတန်းကို ပြောင်းပေးသည် ၊ Scrollspy ကို Bootstrap nav အစိတ်အပိုင်း သို့မဟုတ် list group နှင့် တွဲဖက်အသုံးပြုရာတွင် အကောင်းဆုံးဖြစ်သည် ၊ သို့သော် ၎င်းသည် လက်ရှိစာမျက်နှာရှိ မည်သည့် anchor element နှင့်မဆို တွဲဖက်အသုံးပြုနိုင်မည်ဖြစ်သည်။ ဒါက ဘယ်လိုအလုပ်လုပ်လဲ။idhref

  • စတင်ရန်၊ scrollspy တွင် အချက်နှစ်ချက် လိုအပ်သည်- လမ်းညွှန်ချက်တစ်ခု၊ စာရင်းအုပ်စု သို့မဟုတ် ရိုးရှင်းသော လင့်ခ်အစုံနှင့် လှိမ့်နိုင်သော ကွန်တိန်နာတစ်ခု လိုအပ်သည်။ လှိမ့်နိုင်သော ကွန်တိန်နာ သည် အစုံလိုက် နှင့် <body>စိတ်ကြိုက်ဒြပ်စင်တစ်ခု ဖြစ်နိုင်သည်။heightoverflow-y: scroll

  • ရွှေ့နိုင်သော ကွန်တိန်နာတွင်၊ ဆက်စပ်လမ်းကြောင်းပြခြင်း ၏ ထူးခြား သည့်နေရာကို ပေါင်းထည့် data-bs-spy="scroll"ပါ ။ ကီးဘုတ်အသုံးပြုခွင့်သေချာစေရန် လည်း ထည့်သွင်း ရန်သေချာပါစေ။data-bs-target="#navId"navIdidtabindex="0"

  • သင် "spied" ကွန်တိန်နာကို လှိမ့် .activeလိုက်သည်နှင့် ဆက်စပ်လမ်းကြောင်းပြမှုအတွင်း အတန်းတစ်ခုကို ပေါင်းထည့်ကာ ဆက်စပ်နေသော လမ်းကြောင်းပြလင့်ခ်များမှ ဖယ်ရှားသည်။ လင့်ခ်များတွင် ဖြေရှင်းနိုင်သော ပစ်မှတ်များ ရှိရမည် id၊ သို့မဟုတ်ပါက ၎င်းတို့ကို လျစ်လျူရှုထားသည်။ ဥပမာအားဖြင့်၊ <a href="#home">home</a>DOM ကဲ့သို့သော အရာတစ်ခုနှင့် ကိုက်ညီရမည်။<div id="home"></div>

  • မမြင်နိုင်သော ပစ်မှတ်များကို လျစ်လျူရှုပါမည်။ အောက်တွင် မမြင်နိုင်သောဒြပ်စင်များ ကဏ္ဍကိုကြည့်ပါ ။

ဥပမာများ

navbar အောက်ရှိ ဧရိယာကို ရွှေ့ပြီး တက်ကြွသော အတန်းပြောင်းလဲမှုကို ကြည့်ရှုပါ။ dropdown menu ကိုဖွင့်ပြီး dropdown items များကိုမီးမောင်းထိုးပြထားသည်ကိုကြည့်ပါ။

ပထမခေါင်းစဉ်

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ဒုတိယခေါင်းစဉ်

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

တတိယခေါင်းစဉ်

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

စတုတ္ထခေါင်းစဉ်

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ပဉ္စမ ခေါင်းစဉ်

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

<nav id="navbar-example2" class="navbar bg-light px-3 mb-3">
  <a class="navbar-brand" href="#">Navbar</a>
  <ul class="nav nav-pills">
    <li class="nav-item">
      <a class="nav-link" href="#scrollspyHeading1">First</a>
    </li>
    <li class="nav-item">
      <a class="nav-link" href="#scrollspyHeading2">Second</a>
    </li>
    <li class="nav-item dropdown">
      <a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#" role="button" aria-expanded="false">Dropdown</a>
      <ul class="dropdown-menu">
        <li><a class="dropdown-item" href="#scrollspyHeading3">Third</a></li>
        <li><a class="dropdown-item" href="#scrollspyHeading4">Fourth</a></li>
        <li><hr class="dropdown-divider"></li>
        <li><a class="dropdown-item" href="#scrollspyHeading5">Fifth</a></li>
      </ul>
    </li>
  </ul>
</nav>
<div data-bs-spy="scroll" data-bs-target="#navbar-example2" data-bs-root-margin="0px 0px -40%" data-bs-smooth-scroll="true" class="scrollspy-example bg-light p-3 rounded-2" tabindex="0">
  <h4 id="scrollspyHeading1">First heading</h4>
  <p>...</p>
  <h4 id="scrollspyHeading2">Second heading</h4>
  <p>...</p>
  <h4 id="scrollspyHeading3">Third heading</h4>
  <p>...</p>
  <h4 id="scrollspyHeading4">Fourth heading</h4>
  <p>...</p>
  <h4 id="scrollspyHeading5">Fifth heading</h4>
  <p>...</p>
</div>

Nested nav

Scrollspy သည် nested .navs နှင့်လည်းအလုပ်လုပ်သည်။ အသိုက်တစ်ခုရှိလျှင် .nav၎င်း၏ .activeမိဘများလည်း ရှိလိမ့်မည် .active။ navbar ဘေးရှိ ဧရိယာကို ရွှေ့ပြီး တက်ကြွသော အတန်းပြောင်းလဲမှုကို ကြည့်ရှုပါ။

ပစ္စည်း ၁

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

အကြောင်းအရာ ၁-၁

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

အကြောင်းအရာ ၁-၂

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

ပစ္စည်း ၂

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

အကြောင်းအရာ ၃

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

အကြောင်းအရာ ၃-၁

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

အကြောင်းအရာ ၃-၂

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

JavaScript ပလပ်အင်သည် မြင်နိုင်သည့်အရာအားလုံးကြားတွင် မှန်ကန်သောဒြပ်စင်ကို ရွေးရန် ကြိုးစားကြောင်း သတိရပါ။ တစ်ချိန်တည်းတွင် မြင်နိုင်သော scrollspy ပစ်မှတ်အများအပြားသည် ပြဿနာအချို့ကို ဖြစ်စေနိုင်သည်။

<div class="row">
  <div class="col-4">
    <nav id="navbar-example3" class="h-100 flex-column align-items-stretch pe-4 border-end">
      <nav class="nav nav-pills flex-column">
        <a class="nav-link" href="#item-1">Item 1</a>
        <nav class="nav nav-pills flex-column">
          <a class="nav-link ms-3 my-1" href="#item-1-1">Item 1-1</a>
          <a class="nav-link ms-3 my-1" href="#item-1-2">Item 1-2</a>
        </nav>
        <a class="nav-link" href="#item-2">Item 2</a>
        <a class="nav-link" href="#item-3">Item 3</a>
        <nav class="nav nav-pills flex-column">
          <a class="nav-link ms-3 my-1" href="#item-3-1">Item 3-1</a>
          <a class="nav-link ms-3 my-1" href="#item-3-2">Item 3-2</a>
        </nav>
      </nav>
    </nav>
  </div>

  <div class="col-8">
    <div data-bs-spy="scroll" data-bs-target="#navbar-example3" data-bs-smooth-scroll="true" class="scrollspy-example-2" tabindex="0">
      <div id="item-1">
        <h4>Item 1</h4>
        <p>...</p>
      </div>
      <div id="item-1-1">
        <h5>Item 1-1</h5>
        <p>...</p>
      </div>
      <div id="item-1-2">
        <h5>Item 1-2</h5>
        <p>...</p>
      </div>
      <div id="item-2">
        <h4>Item 2</h4>
        <p>...</p>
      </div>
      <div id="item-3">
        <h4>Item 3</h4>
        <p>...</p>
      </div>
      <div id="item-3-1">
        <h5>Item 3-1</h5>
        <p>...</p>
      </div>
      <div id="item-3-2">
        <h5>Item 3-2</h5>
        <p>...</p>
      </div>
    </div>
  </div>
</div>

အုပ်စုစာရင်း

Scrollspy သည် s နှင့်လည်းအလုပ်လုပ်သည် .list-group။ စာရင်းအုပ်စုဘေးရှိ ဧရိယာကို ရွှေ့ပြီး တက်ကြွသော အတန်းပြောင်းလဲမှုကို ကြည့်ရှုပါ။

ပစ္စည်း ၁

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ပစ္စည်း ၂

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

အကြောင်းအရာ ၃

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ပစ္စည်း ၄

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

<div class="row">
  <div class="col-4">
    <div id="list-example" class="list-group">
      <a class="list-group-item list-group-item-action" href="#list-item-1">Item 1</a>
      <a class="list-group-item list-group-item-action" href="#list-item-2">Item 2</a>
      <a class="list-group-item list-group-item-action" href="#list-item-3">Item 3</a>
      <a class="list-group-item list-group-item-action" href="#list-item-4">Item 4</a>
    </div>
  </div>
  <div class="col-8">
    <div data-bs-spy="scroll" data-bs-target="#list-example" data-bs-smooth-scroll="true" class="scrollspy-example" tabindex="0">
      <h4 id="list-item-1">Item 1</h4>
      <p>...</p>
      <h4 id="list-item-2">Item 2</h4>
      <p>...</p>
      <h4 id="list-item-3">Item 3</h4>
      <p>...</p>
      <h4 id="list-item-4">Item 4</h4>
      <p>...</p>
    </div>
  </div>
</div>

ရိုးရိုးကျောက်ဆူးများ

Scrollspy သည် nav အစိတ်အပိုင်းများနှင့် စာရင်းအုပ်စုများအတွက် အကန့်အသတ်မရှိပါ၊ ထို့ကြောင့် ၎င်းသည် <a>လက်ရှိစာရွက်စာတမ်းရှိ မည်သည့်ကျောက်ဆူးဒြပ်စင်ပေါ်တွင်မဆို လုပ်ဆောင်နိုင်မည်ဖြစ်သည်။ ဧရိယာကို ရွှေ့ပြီး .activeအတန်းပြောင်းလဲမှုကို ကြည့်ရှုပါ။

ပစ္စည်း ၁

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ပစ္စည်း ၂

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

အကြောင်းအရာ ၃

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ပစ္စည်း ၄

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

ပစ္စည်း ၅

ဤသည်မှာ scrollspy စာမျက်နှာအတွက် နေရာယူထားသော အကြောင်းအရာအချို့ဖြစ်သည်။ စာမျက်နှာအောက်သို့ ဆင်းသွားသည့်အခါ သင့်လျော်သော လမ်းညွှန်လင့်ခ်ကို မီးမောင်းထိုးပြထားကြောင်း သတိပြုပါ။ အစိတ်အပိုင်း ဥပမာတစ်ခုလုံးကို ထပ်ခါတလဲလဲ ပြုလုပ်ထားသည်။ လှိမ့်ခြင်းနှင့် မီးမောင်းထိုးပြခြင်းတို့ကို အလေးထားရန် ဤနေရာတွင် နမူနာကော်ပီအချို့ကို ဆက်လက်ထည့်သွင်းထားပါသည်။

<div class="row">
  <div class="col-4">
    <div id="simple-list-example" class="d-flex flex-column gap-2 simple-list-example-scrollspy text-center">
      <a class="p-1 rounded" href="#simple-list-item-1">Item 1</a>
      <a class="p-1 rounded" href="#simple-list-item-2">Item 2</a>
      <a class="p-1 rounded" href="#simple-list-item-3">Item 3</a>
      <a class="p-1 rounded" href="#simple-list-item-4">Item 4</a>
      <a class="p-1 rounded" href="#simple-list-item-5">Item 5</a>
    </div>
  </div>
  <div class="col-8">
    <div data-bs-spy="scroll" data-bs-target="#simple-list-example" data-bs-offset="0" data-bs-smooth-scroll="true" class="scrollspy-example" tabindex="0">
      <h4 id="simple-list-item-1">Item 1</h4>
      <p>...</p>
      <h4 id="simple-list-item-2">Item 2</h4>
      <p>...</p>
      <h4 id="simple-list-item-3">Item 3</h4>
      <p>...</p>
      <h4 id="simple-list-item-4">Item 4</h4>
      <p>...</p>
      <h4 id="simple-list-item-5">Item 5</h4>
      <p>...</p>
    </div>
  </div>
</div>

မမြင်နိုင်သောဒြပ်စင်များ

မမြင်နိုင်သော ပစ်မှတ်များကို လျစ်လျူရှုမည်ဖြစ်ပြီး ၎င်းတို့၏ သက်ဆိုင်ရာ nav ပစ္စည်းများသည် .activeအတန်းကို လက်ခံရရှိမည်မဟုတ်ပါ။ မမြင်နိုင်သော ထုပ်ပိုးမှုတွင် အစပြုခဲ့သော Scrollspy ဖြစ်ရပ်များသည် ပစ်မှတ်ဒြပ်စင်အားလုံးကို လျစ်လျူရှုပါမည်။ refreshwrapper ကိုမြင်သည်နှင့်မြင်နိုင်သောဒြပ်စင်များကိုစစ်ဆေးရန်နည်းလမ်းကို သုံး ပါ။

document.querySelectorAll('#nav-tab>[data-bs-toggle="tab"]').forEach(el => {
  el.addEventListener('shown.bs.tab', () => {
    const target = el.getAttribute('data-bs-target')
    const scrollElem = document.querySelector(`${target} [data-bs-spy="scroll"]`)
    bootstrap.ScrollSpy.getOrCreateInstance(scrollElem).refresh()
  })
})

အသုံးပြုမှု

ဒေတာဂုဏ်တော်များမှတဆင့်

သင်၏ topbar လမ်းညွှန်မှုတွင် scrollspy အပြုအမူကို အလွယ်တကူထည့်ရန်၊ သင် data-bs-spy="scroll"စူးစမ်းလိုသောဒြပ်စင်သို့ ထည့်ပါ (ပုံမှန်အားဖြင့် ၎င်းသည် အများစုဖြစ်မည် <body>)။ ထို့နောက် မည်သည့် Bootstrap အစိတ်အပိုင်း၏ ပင်မဒြပ်စင်၏ အတန်းအမည် သို့မဟုတ် data-bs-targetအရည်အချင်းကို ထည့်သွင်းပါ ။id.nav

<body data-bs-spy="scroll" data-bs-target="#navbar-example">
  ...
  <div id="navbar-example">
    <ul class="nav nav-tabs" role="tablist">
      ...
    </ul>
  </div>
  ...
</body>

JavaScript မှတဆင့်

const scrollSpy = new bootstrap.ScrollSpy(document.body, {
  target: '#navbar-example'
})

ရွေးချယ်စရာများ

ရွေးချယ်မှုများကို ဒေတာ attributes သို့မဟုတ် JavaScript မှတဆင့် ကျော်ဖြတ်နိုင်သောကြောင့်၊ သင်သည် ရွေးချယ်မှုအမည်တစ်ခုအား ထည့်သွင်း data-bs-နိုင်သည် data-bs-animation="{value}"။ ဒေတာ attribute များမှတစ်ဆင့် ရွေးချယ်မှုများကို ဖြတ်သန်းသည့်အခါ “ camelCase ” မှ “ kebab-case ” သို့ ရွေးချယ်မှုအမည်၏ case အမျိုးအစားကို ပြောင်းလဲရန် သေချာပါစေ ။ ဥပမာအားဖြင့်၊ data-bs-custom-class="beautifier"အစားကို သုံးပါ data-bs-customClass="beautifier"

Bootstrap 5.2.0 အရ၊ အစိတ်အပိုင်းအားလုံးသည် JSON စာကြောင်းကဲ့သို့ ရိုးရှင်းသော အစိတ်အပိုင်းဖွဲ့စည်းမှုပုံစံကို ထားရှိပေးနိုင်သည့် စမ်းသပ် လက်ဝယ်ထားသော ဒေတာ attribute ကို ပံ့ပိုးပေးပါသည်။ data-bs-configဒြပ်စင်တစ်ခုတွင် ရည်ညွှန်းချက်ပါရှိသည့်အခါ ၊ နောက်ဆုံး တန်ဖိုးသည် ဖြစ်မည်ဖြစ်ပြီး သီးခြားဒေ data-bs-config='{"delay":0, "title":123}'တာ attribute များသည် ပေးထားသောတန်ဖိုးများကို အစားထိုးမည်ဖြစ်သည် ။ ထို့အပြင်၊ ရှိပြီးသားဒေတာ attribute များသည် JSON တန်ဖိုးများကဲ့သို့ နေရာယူနိုင်သည် ။data-bs-title="456"title456data-bs-configdata-bs-delay='{"show":0,"hide":150}'

နာမည် ရိုက်ပါ။ ပုံသေ ဖော်ပြချက်
rootMargin ကြိုးတစ်ချောင်း 0px 0px -25% လှိမ့်အနေအထားကို တွက်ချက်သောအခါ၊ Intersection Observer rootMargin သည် တရားဝင်ယူနစ်များ။
smoothScroll ဘူလီယံ false ScrollSpy ကို ရည်ညွှန်းသည့် လင့်ခ်တစ်ခုကို အသုံးပြုသူတစ်ဦးက နှိပ်သည့်အခါ ချောမွေ့စွာ လှိမ့်ခြင်းကို ဖွင့်ပေးသည်။
target string၊ DOM ဒြပ်စင် null Scrollspy ပလပ်အင်ကို အသုံးပြုရန် အစိတ်အပိုင်းကို သတ်မှတ်သည်။
threshold ဇွတ် [0.1, 0.5, 1] IntersectionObserver Scroll အနေအထားကို တွက်ချက်သောအခါ မှန်ကန်သောထည့်သွင်းမှု အဆင့်သတ်မှတ်ချက် ။

ကန့်ကွက်ထားသော ရွေးစရာများ

v5.1.3 မတိုင်မီအထိ ကျွန်ုပ်တို့သည် offset& methodoptions များကို အသုံးပြုခဲ့ပြီး၊ ယခု ရပ်ဆိုင်းလိုက်ပြီး အစားထိုး လိုက်ပါသည် rootMarginoffsetနောက်ပြန်လိုက်ဖက်မှုရှိနေ စေရန် ၊ ကျွန်ုပ်တို့သည် ပေးထားသည့်အရာကို ဆက်လက်ခွဲခြမ်းစိတ်ဖြာသွားမည်ဖြစ်ပြီး rootMargin၊ သို့သော် ဤအင်္ဂါရပ်ကို v6 တွင် ဖယ်ရှားပါမည် ။

နည်းလမ်းများ

နည်းလမ်း ဖော်ပြချက်
dispose ဒြပ်စင်တစ်ခု၏ scrollspy ကိုဖျက်ပါ။ (DOM ဒြပ်စင်ပေါ်ရှိ သိမ်းဆည်းထားသည့် ဒေတာကို ဖယ်ရှားသည်)
getInstance DOM ဒြပ်စင်တစ်ခုနှင့်ဆက်စပ်သော scrollspy instance ကိုရယူရန် static နည်းလမ်း။
getOrCreateInstance DOM ဒြပ်စင်တစ်ခုနှင့်ဆက်စပ်နေသော scrollspy instance ကိုရယူရန် သို့မဟုတ် စတင်မလုပ်ဆောင်ပါက အသစ်တစ်ခုဖန်တီးရန် တည်ငြိမ်သော နည်းလမ်း။
refresh DOM တွင် ဒြပ်စင်များထည့်ခြင်း သို့မဟုတ် ဖယ်ရှားသည့်အခါ၊ ပြန်လည်ဆန်းသစ်သည့်နည်းလမ်းကို သင်ခေါ်ဆိုရန် လိုအပ်ပါသည်။

ဤသည်မှာ ပြန်လည်ဆန်းသစ်ခြင်းနည်းလမ်းကို အသုံးပြုထားသော ဥပမာတစ်ခုဖြစ်သည်။

const dataSpyList = document.querySelectorAll('[data-bs-spy="scroll"]')
dataSpyList.forEach(dataSpyEl => {
  bootstrap.ScrollSpy.getInstance(dataSpyEl).refresh()
})

အဲ့ဒါနဲ့

ပွဲ ဖော်ပြချက်
activate.bs.scrollspy Scrollspy မှ ကျောက်ဆူးတစ်ခုအား စတင်သည့်အခါတိုင်း ဤဖြစ်ရပ်သည် လှိမ့်ဒြပ်ပေါ်တွင် လောင်ကျွမ်းသွားပါသည်။
const firstScrollSpyEl = document.querySelector('[data-bs-spy="scroll"]')
firstScrollSpyEl.addEventListener('activate.bs.scrollspy', () => {
  // do something...
})