부트 스트랩 드롭 다운이 작동하지 않음


81

작동하도록 부트 스트랩 드롭 다운을 만들 수 없습니다. 다음은 내비게이션 용 HTML입니다.

<ul class='nav'>
  <li class='active'>Home</li>
  <li class='dropdown'>
    <a class="dropdown-toggle" data-toggle="dropdown" href='#'>Personal asset loans</a>
    <ul class="dropdown-menu" role="menu">
      <li><a href="#">asds</a></li>
      <li class="divider"></li>
    </ul>
  </li>
  <li>Payday loans</li>
  <li>About</li>
  <li>Contact</li>
</ul>

다음은 스크립트입니다.

<script type="text/javascript" src="js/bootstrap/bootstrap-dropdown.js"></script>
<script>
     $(document).ready(function(){
        $('.dropdown-toggle').dropdown()
    });
</script>

내가 도대체 ​​뭘 잘못하고있는 겁니까? 답변 해 주셔서 감사합니다!


비슷한 게시물에서 내 대답을 확인하십시오. stackoverflow.com/questions/15592158/…
Tejasvi Hegde

4
내 문제는 다른 사람을 도움이 경우 부트 스트랩 JS 파일이 누락 된
Drewdavid

내가 업데이트 한 내 Gruntfile.js에서 일부 경로를 변경 jsFileList경로를 업데이트하고 (꿀꿀 DEV / 꿀꿀 빌드 / 등) 내 문제를 해결 적절한 그런트 작업을 실행 ....
Ken Prince

1
@Drewdavid 감사합니다! 나는 실종 bootstrap.min.js 되었고 jquery
lucidbrot

답변:


11

작동 데모 : http://codebins.com/bin/4ldqp73

이 시도

<ul class='nav'>
  <li class='active'>Home</li>
  <li>
    <div class="dropdown">
      <a class="dropdown-toggle" data-toggle="dropdown" href="#">Personal asset loans</a>
      <ul class="dropdown-menu" role="menu" aria-labelledby="dLabel">            
        <li><a href="#">asds</a></li>
        <li class="divider"></li>
      </ul>
    </div>   
    </li>
    <li>Payday loans</li>
  <li>About</li>
  <li>Contact</li>
</ul>

57
데모의 드롭 다운이 더 이상 작동하지 않거나 내 브라우저에 문제가있는 것 같습니다.
Noah

154

나는 같은 문제가 있었다. 몇 시간의 문제 해결 후

나는 가지고 있었다

<script type="text/javascript" src="Scripts/bootstrap.min.js"></script>
<script type="text/javascript" src="Scripts/jquery-2.1.1.min.js"></script>

대신에,

<script type="text/javascript" src="Scripts/jquery-2.1.1.min.js"></script>
<script type="text/javascript" src="Scripts/bootstrap.min.js"></script>

이것이 누군가에게 도움이되기를 바랍니다.


1
차이점이 뭐야?
CodyBugstein 2014 년

9
Imray, 부트 스트랩 스크립트는 jQuery에 확장을 등록하므로 jQUery가로드되지 않으면 확장이 등록되지 않습니다.
Amoliski 2014

2
순서는 참으로 중요합니다. 도와 주셔서 감사합니다!
K.Land_bioinfo jul.

감사. angular.json 파일의 angular 10 프로젝트에서도 작업했습니다
shawon

86

bootstrap.min.js두 번 포함했을 때도 같은 문제가 발생 했습니다. 그중 하나를 제거하고 작동하기 시작했습니다.


1
이것은 내 문제를 해결했습니다. 내 각 응용 프로그램 내 bower_components를 주입하기 위해 꿀꺽 작업을 통해 부트 스트랩의 여러 복사본 당기는되었다
Pakage

이것은 내 문제를 해결했습니다. 감사합니다
YUDU 금지

이 다발와 ASP.NET MVC 5 프로젝트에 고정
Klaasel

나를 위해 고쳤습니다. 감사.
Henry A.

정말 짜증나 ... aurelia-webpack-skeleton을 사용하여 main.js에서 bootstrap.css를 가져와야합니다.하지만 'bootstrap'을 가져 오면 이상한 동작이 나타납니다 ...
아이러니하게도

23

참고 : 당신이 bootstrap.js있는 경우에, 당신은해야 하지 -dropdown.js을 부트 스트랩 추가합니다.

bootstrap.min.js의 결과가 확실하지 않습니다.


2
감사. dropdown.js와 bootstrap.js를 모두 가지고 있었으므로 작동하지 않았습니다. dropdown.js를 제거하면 문제가 해결되었습니다.
nyxz

당신은 최고의 남자입니다, 나는 문제가 어디에 있는지 찾기 위해 약 6 시간을 보냈습니다 !!, 다시 감사합니다 ..
Adel

1
매우 감사합니다! 동일한 문제가 있지만 bootstrap.jsbootstrap.min.js.. 후자를 제거하면 작동합니다.

1
덕분에 - 내 경우에는, 둘 다 가지고 js/bootstrap.js뿐만 아니라js/dropdown.js
산 제이 Manohar

13

스타일을 위해 일반적으로 </head>요소 바로 앞에 부트 스트랩의 CSS 파일을 포함해야합니다.

<link href="css/bootstrap.css" rel="stylesheet">    

다음으로 js 파일을 포함해야합니다. 일반적으로 </body>페이지가 더 빨리로드 되기 전에 문서 끝에 포함하는 것이 좋습니다 .

<script src="js/jquery.js"></script>        
<script src="js/bootstrap.js"></script>

8

본문 태그 내에 다음 줄을 추가합니다.

<!-- jQuery (necessary for Bootstrap's JavaScript plugins) -->
  <script src="https://code.jquery.com/jquery.js"></script>
  <!-- Include all compiled plugins (below), or include individual files 
        as needed -->
  <script src="js/bootstrap.min.js"></script>

감사합니다. 시간을 절약했습니다.
DrewT

7

이 파일을 <head></head>html 로 가져와야합니다 .

<script src="http://code.jquery.com/jquery-1.11.0.min.js"></script>
<script src="http://code.jquery.com/jquery-migrate-1.2.1.min.js"></script>
<link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css">
<script src="//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>

1
나는 내가 왜 또는 무엇을 잘못하고 있는지 전혀 모르지만이 대답은 나를 위해 그것을했습니다. 고마워요 마틴!
dghalbr

감사합니다. 왜 이것이 문제를 해결했는지 모르겠습니다. 메뉴는 웹 사이트가 다른 Windows 서버로 마이그레이션 될 때까지 /js/jquery.js 및 /js/bootstrap.min.js에서 제대로 작동했습니다.
Hong

5

포함 시켰 jquery.js습니까?

또한 다음 코드 줄을 귀하의 코드와 비교하십시오.

<a class="dropdown-toggle" data-toggle="dropdown" href="#">Personal asset loans<b class="caret"></b></a>

정상적으로 작동하는이 버전을 참조하십시오.

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>Bootstrap dropdown</title>
    <link href="css/bootstrap.css" rel="stylesheet" type="text/css" />

</head>
<body>
    <div class="navbar">
        <div class="navbar-inner">
            <div class="container">
                <ul class="nav">
                    <a class="brand" href="#">w3resource</a>
                    <li class="active"><a href="#">Home</a></li>
                    <li><a href="#">Blog</a></li>
                    <li><a href="#">About</a></li>
                    <li><a href="#">Contact</a></li>
                    <li class="dropdown" id="accountmenu">
                        <a class="dropdown-toggle" data-toggle="dropdown" href="#">Tutorials<b class="caret"></b></a>
                        <ul class="dropdown-menu">
                            <li><a href="#">PHP</a></li>
                            <li><a href="#">MySQL</a></li>
                            <li class="divider"></li>
                            <li><a href="#">JavaScript</a></li>
                            <li><a href="#">HTML5</a></li>
                        </ul>
                    </li>
                </ul>
            </div>
        </div>
    </div>
    <div class="container-fluid">
     <h1>Dropdown Example</h1>
    </div>
    <script type="text/javascript" src="js/jquery-latest.js"></script>
    <script type="text/javascript" src="js/bootstrap.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            $('.dropdown-toggle').dropdown();
        });
   </script>
</body>
</html>

4

부트 스트랩과 jquery가 모두 포함되어야합니다.

<link type="text/css" href="/{ProjectName}/css/ui-lightness/jquery-ui-1.8.18.custom.css" rel="stylesheet" />
<script type="text/javascript" src="/{ProjectName}/js/jquery-x.x.x.custom.min.js"></script>

<link type="text/css" href="/{ProjectName}/css/bootstrap.css" rel="stylesheet" />
<script type="text/javascript" src="/{ProjectName}/js/bootstrap.js"></script>

참고 : jquery-xxxmin.js 버전 은 2.xx 버전 이어야합니다 !!!


4

나는 그것을 알아 냈고 이것을하는 가장 간단한 방법은 https://www.bootstrapcdn.com/ 에서 찾을 수있는 부트 스트랩 링크의 CDN 과 여기에서 찾을 수있는 Jquery CDN 스크립트 https : // code.jquery.com/ 링크를 복사 한 후 부트 스트랩 링크는 HTML 헤드에 붙여넣고 Jquery 스크립트는 아래 예와 같이 HTML 본문에 붙여 넣습니다.

    <!DOCTYPE html>
    <html>
      <head>

        <title>Purrfect Match Landing Page</title>
        <!-- Latest compiled and minified CSS -->
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
        <!--<link rel="stylesheet" href="griddemo.css">

        <!-- Optional theme -->
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css">
        <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">

      </head>

      <body>

        <!-- Latest compiled and minified JavaScript -->
        <script src="https://code.jquery.com/jquery-3.1.1.js"></script>
        <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js">      </script>    
      </body>
    </html>

나를 위해 완벽한 희망을 작동합니다.


감사합니다 ! , </body>태그가 내 쪽에서 작동 하기 전에 이동 !
Ryan Aquino

2

머리 부분에서 이것을 시도하십시오

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>
<script src="//netdna.bootstrapcdn.com/bootstrap/3.1.1/js/bootstrap.min.js"></script>
<link rel="stylesheet" type="text/css" href="//netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap.min.css">

2

내가 한 일은 .....

내 프로젝트에서 bootstrap.min.js를 제거하고 여기에 bootstrap.js를 추가하면 작동하기 시작했습니다 ........

bundles.Add(new ScriptBundle("~/bundles/bootstrap").Include(
                  "~/Scripts/bootstrap.js"
                  //"~/Scripts/bootstrap.min.js"));

#kubilay 답변에 추가 : 문서 당 'A'라는 단일 클래스를 가질 수 있습니다. .min.css / .min.js-일반적으로 모든 공백이 제거 된 동일한 css 및 js 파일입니다. 크기가 작아지고로드 속도가 빨라집니다. 어쨌든 브라우저에는 공백이 필요하지 않습니다.
Mohit Dhawan 2016 년

둘 다 사용한 경우 하나를 제거하십시오
Mohit Dhawan 2016-06-08

2

이 코드를 시도하십시오.

<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Bootstrap Tutorial</title>
  <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">
</head>
<body>
    <h1>Welcome to Bootstrap</h1>
    <div class="dropdown">
        <button class="btn btn-secondary dropdown-toggle" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
            Dropdown button
        </button>
        <div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
            <a class="dropdown-item" href="#">Action</a>
            <a class="dropdown-item" href="#">Another action</a>
            <a class="dropdown-item" href="#">Something else here</a>
        </div>
    </div>


    <script src="https://code.jquery.com/jquery.js"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.bundle.min.js"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></script>
</body>
</html>

1

충돌하는 css 파일 / 속성을 확인해야합니다. 예를 들어 ".nav"사용자 지정 스타일 콘텐츠가 다른 곳에서 자신의 CSS 파일을 비활성화하고 작동하는지 확인한 다음 충돌을 일으키는 파일 또는 사용자 지정 스타일도 확인해야합니다. 코드에 bootstrap.min.js를 포함하고 있습니다.


1

나는 부트 스트랩 스크립트를 두 번 추가했고 번째 부트 스트랩 스크립트가 jquery 스크립트 위에 있다는 것을 관찰하기 위해서만 비슷한 문제가있었습니다 .

해결책:

  • bootstrap.min.js 및 jquery.min.js가 파일에 한 번만 포함되어 있는지 확인하십시오.
  • bootstrap.min.js 스크립트는 jquery.min.js 뒤에 포함되어야합니다.

1

jQuery를 아래에 복사 - 붙여 넣기 <script>및 스타일 시트 <link>당신에 <head>당신이있는 거로드 필요한 모든 파일 확인.

JQuery .js파일이 .css스타일 시트 위에있는 것이 중요합니다.

테스트하려면 다음 줄을 붙여 넣으십시오.

<script src="//ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="//netdna.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></script>
<link rel="stylesheet" type="text/css" href="//netdna.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">

문제는 주로 jQuery 스크립트를로드 할 때 발생합니다. 참조를 올바르게 추가했는지 확인하십시오.

이제 테스트

그래도 작동하지 않으면 샘플 구현이있는 부트 스트랩 웹 사이트를 확인하세요.

https://getbootstrap.com/docs/4.3/components/navbar/#supported-content


1

최신 부트 스트랩의 경우 Popper.js 가 필요 합니다.

<script src="http://code.jquery.com/jquery-1.11.0.min.js"></script> 
<link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css">
<script src="//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>

<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"></script>

<body>태그 바로 앞, 태그 내부 의 본문 끝 섹션에있는 링크를 복사합니다 <Head>.


1

방금 색인 페이지 에 JS일부를 추가 bootstrap했는데 최신 버전의 부트 스트랩을 사용하는 경우 붙여 넣기가 작동했습니다.


<script src="https://code.jquery.com/jquery-3.5.1.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj" crossorigin="anonymous"></script>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@4.5.3/dist/js/bootstrap.bundle.min.js" integrity="sha384-ho+j7jyWK8fNQe+A12Hb8AhRq26LrZ/JpcUGGOn+Y7RsweNrtN/tE3MoK7ZeZDyx" crossorigin="anonymous"></script>

그것은 ... 수락 된 대답과 8 + 세 질문
Zsolt 메스 자 로스

@ZsoltMeszaros 네, 알아요. 그러나이 문제에 직면 할 수있는 다른 사람이있다
mecdeality

0

나는 나를 여기로 가져온 동일한 문제가 있었다.

내 문제 : 권장 jquery 1.12.0 버전을 jquery 스크립트 파일로 사용하고있었습니다.

솔루션 : jquery 스크립트를 jquery 2.2.0 버전으로 대체했습니다.

그것은 나를 위해 그것을 해결했습니다.


0

저에게는 CORS 문제였습니다. crossorigin="anonymous"내 스크립트 가져 오기 태그에서 제거 하고 다시 작동하기 시작했습니다.

BTW 올바른 순서의 최신 스크립트 태그는 항상 여기에서 찾을 수 있습니다 : https://getbootstrap.com/

편집 : 분명히 태그에 추가 defer하면 script모든 부트 스트랩 혜택이 깨집니다.


0

여기에 부트 스트랩 사이트의 JS 링크 다음에 CSS 링크를 복사하여 붙여 넣습니다 . 그러면 드롭 다운이 작동합니다.

내 페이지는 다음과 같습니다.

<html>
  <head>
    <meta charset="utf-8">
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>

    <title>Website Title</title>
  </head>
  <body>
    <div id="content" />
    <nav class="navbar navbar-expand-lg navbar-light bg-light">
      <a class="navbar-brand" href="#">Navbar</a>
      <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
        <span class="navbar-toggler-icon"></span>
      </button>
      <div class="collapse navbar-collapse" id="navbarSupportedContent">
        <ul class="navbar-nav mr-auto">
          <li class="nav-item active">
            <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a>
          </li>
          <li class="nav-item">
            <a class="nav-link" href="#">Link</a>
          </li>
          <li class="nav-item dropdown">
            <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
              Dropdown
            </a>
            <div class="dropdown-menu" aria-labelledby="navbarDropdown">
              <a class="dropdown-item" href="#">Action</a>
              <a class="dropdown-item" href="#">Another action</a>
              <div class="dropdown-divider"></div>
              <a class="dropdown-item" href="#">Something else here</a>
            </div>
          </li>
          <li class="nav-item">
            <a class="nav-link disabled" href="#">Disabled</a>
          </li>
        </ul>
        <form class="form-inline my-2 my-lg-0">
          <input class="form-control mr-sm-2" type="search" placeholder="Search" aria-label="Search">
          <button class="btn btn-outline-success my-2 my-sm-0" type="submit">Search</button>
        </form>
      </div>
    </nav>
  </body>
</html>

( 여기 에서 Navbar )


0

동일한 문제가 있었기 때문에 popper.js 라이브러리를 확인하십시오. https://getbootstrap.com/ 에서 드롭 다운에 대한 부트 스트랩, jquery 및 popper CDN을 찾을 수 있습니다. 또는 jus는 다음 스크립트 태그를 복사합니다.


0

내 (동일한) 문제는 CSS와 부트 스트랩 버전을 섞었을 때 발생했습니다. 버전 4.5 bootstrap.min.css와 함께 버전 3 bootstrap.min.js를 사용하고있었습니다.

최근에 많은 css 및 js 파일을 정적 폴더에로드하거나 덮어 쓴 경우 시작하기에 좋은 곳입니다.

행운을 빕니다.


-1

Angular 7, jQuery 3.4.1, Popper 1.12.9 및 Bootstrap 4.3.1로 설정했지만 스타일 에서이 작은 해킹을 수행했습니다.

.dropdown.show .dropdown-menu {
    opacity: 1 !important;
}

Html은 다음과 같습니다.

<nav class="navbar navbar-expand-lg navbar-dark fixed-top py-1">
 <div class="container-fluid">
    <ul class="navbar-nav">
        <li class="nav-item dropdown">
            <button class="btn btn-secondary dropdown-toggle" type="button" data-toggle="dropdown" aria-haspopup="true" id="dropdown-id"
                aria-expanded="false">Menu</button>
            <div class="dropdown-menu" aria-labelledby="dropdown-id">
                <a class="dropdown-item" [routerLink]='["/"]'>Main page</a>
                <a class="dropdown-item" [routerLink]='["/about"]'>About</a>
                <div class="dropdown-divider"></div>
                <a class="dropdown-item" [routerLink]='["/about/terms"]'>Terms</a>
                <a class="dropdown-item" [routerLink]='["/about/privacy"]'>Privacy</a>
            </div>
        </li>
     </ul>
  </div>
</nav>
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.