ప్రధాన కంటెంట్‌కు దాటవేయండి డాక్స్ నావిగేషన్‌కు దాటవేయండి
Check
in English

Scrollspy

వీక్షణపోర్ట్‌లో ప్రస్తుతం ఏ లింక్ సక్రియంగా ఉందో సూచించడానికి స్క్రోల్ స్థానం ఆధారంగా బూట్‌స్ట్రాప్ నావిగేషన్ లేదా జాబితా గ్రూప్ భాగాలను స్వయంచాలకంగా నవీకరించండి.

అది ఎలా పని చేస్తుంది

యాంకర్ ద్వారా సూచించబడిన మూలకం వీక్షణలోకి స్క్రోల్ చేయబడినప్పుడు .activeయాంకర్ ( ) మూలకాలపై తరగతిని స్క్రోల్స్‌పై టోగుల్ చేస్తుంది . Scrollspy బూట్‌స్ట్రాప్ nav భాగం లేదా జాబితా సమూహంతో కలిపి ఉత్తమంగా ఉపయోగించబడుతుంది , అయితే ఇది ప్రస్తుత పేజీలోని ఏదైనా యాంకర్ మూలకాలతో కూడా పని చేస్తుంది. ఇది ఎలా పని చేస్తుందో ఇక్కడ ఉంది.<a>idhref

  • ప్రారంభించడానికి, scrollspyకి రెండు విషయాలు అవసరం: నావిగేషన్, జాబితా సమూహం లేదా సాధారణ లింక్‌ల సెట్, స్క్రోల్ చేయగల కంటైనర్. స్క్రోల్ చేయదగిన కంటైనర్ <body>లేదా సెట్ heightమరియు అనుకూల మూలకం కావచ్చు overflow-y: scroll.

  • స్క్రోల్ చేయదగిన కంటైనర్‌లో, అనుబంధిత నావిగేషన్ యొక్క ప్రత్యేకత ఎక్కడ ఉంది data-bs-spy="scroll"మరియు జోడించండి. కీబోర్డ్ యాక్సెస్‌ని నిర్ధారించడానికి aని కూడా చేర్చారని నిర్ధారించుకోండి.data-bs-target="#navId"navIdidtabindex="0"

  • మీరు “స్పైడ్” కంటైనర్‌ను స్క్రోల్ చేస్తున్నప్పుడు .active, అనుబంధిత నావిగేషన్‌లోని యాంకర్ లింక్‌ల నుండి ఒక తరగతి జోడించబడుతుంది మరియు తీసివేయబడుతుంది. లింక్‌లు తప్పనిసరిగా పరిష్కరించగల idలక్ష్యాలను కలిగి ఉండాలి, లేకుంటే అవి విస్మరించబడతాయి. ఉదాహరణకు, <a href="#home">home</a>DOMలో ఏదో ఒక దానికి అనుగుణంగా ఉండాలి<div id="home"></div>

  • కనిపించని లక్ష్య అంశాలు విస్మరించబడతాయి. దిగువన కనిపించని మూలకాల విభాగాన్ని చూడండి .

ఉదాహరణలు

నావ్‌బార్ దిగువన ఉన్న ప్రాంతాన్ని స్క్రోల్ చేయండి మరియు సక్రియ తరగతి మార్పును చూడండి. డ్రాప్‌డౌన్ మెనుని తెరిచి, డ్రాప్‌డౌన్ ఐటెమ్‌లను కూడా హైలైట్ చేయడాన్ని చూడండి.

మొదటి శీర్షిక

ఇది 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>

నెస్టెడ్ nav

Scrollspy నెస్టెడ్ లతో కూడా పనిచేస్తుంది .nav. ఒక గూడు ఉంటే .nav, .activeదాని తల్లిదండ్రులు కూడా ఉంటారు .active. నావ్‌బార్ ప్రక్కన ఉన్న ప్రాంతాన్ని స్క్రోల్ చేయండి మరియు యాక్టివ్ క్లాస్ మార్పును చూడండి.

అంశం 1

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

జావాస్క్రిప్ట్ ప్లగ్ఇన్ కనిపించే అన్నింటిలో సరైన మూలకాన్ని ఎంచుకోవడానికి ప్రయత్నిస్తుందని గుర్తుంచుకోండి. ఒకే సమయంలో కనిపించే బహుళ స్క్రోల్‌స్పై లక్ష్యాలు కొన్ని సమస్యలను కలిగిస్తాయి.

అంశం 1-1

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

జావాస్క్రిప్ట్ ప్లగ్ఇన్ కనిపించే అన్నింటిలో సరైన మూలకాన్ని ఎంచుకోవడానికి ప్రయత్నిస్తుందని గుర్తుంచుకోండి. ఒకే సమయంలో కనిపించే బహుళ స్క్రోల్‌స్పై లక్ష్యాలు కొన్ని సమస్యలను కలిగిస్తాయి.

అంశం 1-2

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

జావాస్క్రిప్ట్ ప్లగ్ఇన్ కనిపించే అన్నింటిలో సరైన మూలకాన్ని ఎంచుకోవడానికి ప్రయత్నిస్తుందని గుర్తుంచుకోండి. ఒకే సమయంలో కనిపించే బహుళ స్క్రోల్‌స్పై లక్ష్యాలు కొన్ని సమస్యలను కలిగిస్తాయి.

అంశం 2

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

జావాస్క్రిప్ట్ ప్లగ్ఇన్ కనిపించే అన్నింటిలో సరైన మూలకాన్ని ఎంచుకోవడానికి ప్రయత్నిస్తుందని గుర్తుంచుకోండి. ఒకే సమయంలో కనిపించే బహుళ స్క్రోల్‌స్పై లక్ష్యాలు కొన్ని సమస్యలను కలిగిస్తాయి.

అంశం 3

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

జావాస్క్రిప్ట్ ప్లగ్ఇన్ కనిపించే అన్నింటిలో సరైన మూలకాన్ని ఎంచుకోవడానికి ప్రయత్నిస్తుందని గుర్తుంచుకోండి. ఒకే సమయంలో కనిపించే బహుళ స్క్రోల్‌స్పై లక్ష్యాలు కొన్ని సమస్యలను కలిగిస్తాయి.

అంశం 3-1

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

జావాస్క్రిప్ట్ ప్లగ్ఇన్ కనిపించే అన్నింటిలో సరైన మూలకాన్ని ఎంచుకోవడానికి ప్రయత్నిస్తుందని గుర్తుంచుకోండి. ఒకే సమయంలో కనిపించే బహుళ స్క్రోల్‌స్పై లక్ష్యాలు కొన్ని సమస్యలను కలిగిస్తాయి.

అంశం 3-2

ఇది 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 కూడా పని చేస్తుంది .list-group. జాబితా సమూహం పక్కన ఉన్న ప్రాంతాన్ని స్క్రోల్ చేయండి మరియు సక్రియ తరగతి మార్పును చూడండి.

అంశం 1

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 2

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 3

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 4

ఇది 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తరగతి మార్పును చూడండి.

అంశం 1

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 2

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 3

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 4

ఇది scrollspy పేజీ కోసం కొంత ప్లేస్‌హోల్డర్ కంటెంట్. మీరు పేజీని క్రిందికి స్క్రోల్ చేస్తున్నప్పుడు, తగిన నావిగేషన్ లింక్ హైలైట్ చేయబడుతుందని గమనించండి. ఇది కాంపోనెంట్ ఉదాహరణ అంతటా పునరావృతమవుతుంది. స్క్రోలింగ్ మరియు హైలైట్ చేయడాన్ని నొక్కి చెప్పడానికి మేము ఇక్కడ మరికొన్ని ఉదాహరణ కాపీని జోడిస్తూ ఉంటాము.

అంశం 5

ఇది 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 ఉదంతాలు అన్ని లక్ష్య అంశాలను విస్మరిస్తాయి. refreshరేపర్ కనిపించిన తర్వాత పరిశీలించదగిన మూలకాల కోసం తనిఖీ చేయడానికి పద్ధతిని ఉపయోగించండి .

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()
  })
})

వాడుక

డేటా లక్షణాల ద్వారా

మీ టాప్‌బార్ నావిగేషన్‌కు స్క్రోల్‌స్పై ప్రవర్తనను సులభంగా జోడించడానికి, data-bs-spy="scroll"మీరు గూఢచర్యం చేయాలనుకుంటున్న మూలకానికి జోడించండి (సాధారణంగా ఇది <body>). ఆపై ఏదైనా బూట్‌స్ట్రాప్ కాంపోనెంట్ యొక్క పేరెంట్ ఎలిమెంట్ లేదా క్లాస్ పేరుతో 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>

జావాస్క్రిప్ట్ ద్వారా

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

ఎంపికలు

ఎంపికలు డేటా అట్రిబ్యూట్‌లు లేదా జావాస్క్రిప్ట్ ద్వారా పాస్ చేయగలవు కాబట్టి, మీరు ఎంపిక పేరును data-bs-, లో వలె జోడించవచ్చు data-bs-animation="{value}". డేటా అట్రిబ్యూట్‌ల ద్వారా ఆప్షన్‌లను పాస్ చేస్తున్నప్పుడు ఎంపిక పేరు యొక్క కేస్ రకాన్ని “ కామెల్‌కేస్ ” నుండి “ కబాబ్-కేస్ ”కి మార్చాలని నిర్ధారించుకోండి. ఉదాహరణకు, data-bs-custom-class="beautifier"బదులుగా ఉపయోగించండి data-bs-customClass="beautifier".

బూట్‌స్ట్రాప్ 5.2.0 నాటికి, అన్ని భాగాలు JSON స్ట్రింగ్‌గా సాధారణ కాంపోనెంట్ కాన్ఫిగరేషన్‌ను కలిగి ఉండే ప్రయోగాత్మక రిజర్వు చేయబడిన డేటా లక్షణానికి మద్దతు ఇస్తాయి. data-bs-configమూలకం కలిగి ఉన్నప్పుడు data-bs-config='{"delay":0, "title":123}'మరియు data-bs-title="456"లక్షణాలను కలిగి ఉన్నప్పుడు, తుది titleవిలువ ఉంటుంది 456మరియు ప్రత్యేక డేటా లక్షణాలు న ఇచ్చిన విలువలను భర్తీ చేస్తాయి data-bs-config. అదనంగా, ఇప్పటికే ఉన్న డేటా అట్రిబ్యూట్‌లు వంటి JSON విలువలను కలిగి ఉంటాయి data-bs-delay='{"show":0,"hide":150}'.

పేరు టైప్ చేయండి డిఫాల్ట్ వివరణ
rootMargin స్ట్రింగ్ 0px 0px -25% స్క్రోల్ స్థానాన్ని లెక్కించేటప్పుడు ఖండన అబ్జర్వర్ రూట్‌మార్జిన్ చెల్లుబాటు అయ్యే యూనిట్‌లు.
smoothScroll బూలియన్ false ScrollSpy పరిశీలించదగిన వాటిని సూచించే లింక్‌పై వినియోగదారు క్లిక్ చేసినప్పుడు మృదువైన స్క్రోలింగ్‌ని ప్రారంభిస్తుంది.
target స్ట్రింగ్, DOM మూలకం null Scrollspy ప్లగిన్‌ని వర్తింపజేయడానికి మూలకాన్ని నిర్దేశిస్తుంది.
threshold అమరిక [0.1, 0.5, 1] IntersectionObserver థ్రెషోల్డ్ చెల్లుబాటు అయ్యే ఇన్‌పుట్, స్క్రోల్ స్థానాన్ని లెక్కించేటప్పుడు.

నిలిపివేయబడిన ఎంపికలు

v5.1.3 వరకు మేము offset& methodఎంపికలను ఉపయోగిస్తున్నాము, అవి ఇప్పుడు నిలిపివేయబడ్డాయి మరియు భర్తీ చేయబడ్డాయి rootMargin. వెనుకకు అనుకూలతను ఉంచడానికి, మేము ఇచ్చిన దాన్ని అన్వయించడాన్ని కొనసాగిస్తాము offset, కానీ ఈ ఫీచర్ v6rootMargin లో తీసివేయబడుతుంది .

పద్ధతులు

పద్ధతి వివరణ
dispose మూలకం యొక్క scrollspyని నాశనం చేస్తుంది. (DOM మూలకంపై నిల్వ చేసిన డేటాను తొలగిస్తుంది)
getInstance DOM మూలకంతో అనుబంధించబడిన scrollspy ఉదాహరణను పొందడానికి స్టాటిక్ పద్ధతి.
getOrCreateInstance DOM మూలకంతో అనుబంధించబడిన స్క్రోల్‌స్పై ఉదాహరణను పొందడానికి లేదా అది ప్రారంభించబడనట్లయితే కొత్తదాన్ని సృష్టించడానికి స్టాటిక్ పద్ధతి.
refresh DOMలో మూలకాలను జోడించేటప్పుడు లేదా తీసివేసేటప్పుడు, మీరు రిఫ్రెష్ పద్ధతికి కాల్ చేయాల్సి ఉంటుంది.

రిఫ్రెష్ పద్ధతిని ఉపయోగించి ఇక్కడ ఒక ఉదాహరణ ఉంది:

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

ఈవెంట్స్

ఈవెంట్ వివరణ
activate.bs.scrollspy స్క్రోల్‌స్పై యాంకర్ యాక్టివేట్ అయినప్పుడల్లా ఈ ఈవెంట్ స్క్రోల్ ఎలిమెంట్‌పై కాల్పులు జరుపుతుంది.
const firstScrollSpyEl = document.querySelector('[data-bs-spy="scroll"]')
firstScrollSpyEl.addEventListener('activate.bs.scrollspy', () => {
  // do something...
})