semantic-ui下拉菜单不起作用

时间:2014-08-17 07:55:40

标签: javascript html semantic-ui

我一直在尝试使用Semantic-UI构建菜单。我无法让下拉菜单工作。我拿了一份页面Menu examples并删除了除分层菜单以外的所有内容并将其放在一个单独的文件中。尽管没有错误,但只有下拉菜单才会起作用。谁能告诉我我错过了什么?

<html>
  <head>
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="Content-Script-Type" content="text/jscript" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />    
    <link rel="stylesheet" type="text/css" class="ui" href="http://semantic-ui.com/build/packaged/css/semantic.min.css">
    <link rel="stylesheet" type="text/css" href="http://semantic-ui.com/stylesheets/semantic.css">  
    <script src="http://semantic-ui.com/javascript/library/jquery.min.js"></script>
    <script src="http://semantic-ui.com/javascript/library/history.js"></script>
    <script src="http://semantic-ui.com/javascript/library/easing.js"></script>
    <script src="http://semantic-ui.com/javascript/library/ace/ace.js"></script>
    <script src="http://semantic-ui.com/javascript/library/tablesort.js"></script>
    <script src="http://semantic-ui.com/javascript/library/waypoints.js"></script>
    <script src="http://semantic-ui.com/build/packaged/javascript/semantic.min.js"></script>
    <script src="http://semantic-ui.com/javascript/semantic.js"></script>
  </head>
  <body class="menu" >
    <div class="ui tiered menu">
      <div class="menu">
        <a class="active item">
          <i class="users icon"></i>
          Friends
        </a>
        <a class="item">
          <i class="grid layout icon"></i> Browse
        </a>
        <a class="item">
          <i class="mail icon"></i> Messages
        </a>
        <div class="right menu">
          <div class="item">
            <div class="ui icon input">
              <input type="text" placeholder="Search...">
              <i class="search icon"></i>
            </div>
          </div>
          <div class="ui dropdown item">
            More <i class="icon dropdown"></i>
            <div class="menu">
              <a class="item"><i class="edit icon"></i> Edit Profile</a>
              <a class="item"><i class="globe icon"></i> Choose Language</a>
              <a class="item"><i class="settings icon"></i> Account Settings</a>
            </div>
          </div>
        </div>
      </div>
      <div class="ui sub menu">
        <a class="active item">Search</a>
        <a class="item">Add</a>
        <a class="item">Remove</a>
      </div>
    </div>

  </body>
</html>

7 个答案:

答案 0 :(得分:86)

您需要像下面这样初始化您的下拉列表:

$('.ui.dropdown')
  .dropdown();

有更多信息HERE

答案 1 :(得分:53)

一种方法是JS,你需要初始化脚本。其他方法是添加一个类&#34;简单&#34;下拉

<div class="ui simple dropdown item">

答案 2 :(得分:12)

如前所述,您可以:

  • 使用Javascript或
  • 初始化您的下拉列表
  • 使用simple课程。

这两种方式之间有一个非常重要的区别:使用simple类,您不需要Semantic-UI Javascript来使用下拉菜单simple类使用:hover选择器。

请注意,使用simple类(不是Javascript初始化)不会给你很好的下拉效果。

因此,以下代码将在您的页面中显示没有Semantic-UI Javascript的下拉菜单:

<div class="ui simple dropdown item">

答案 3 :(得分:2)

如果您使用$('.ui.dropdown').dropdown();初始化,请确保您的网页引用dropdown.js

答案 4 :(得分:0)

当我在上方添加功能行时

    <script> 
     $(document).ready(function(){
          $('.ui.dropdown') .dropdown();
    });
    </script>

答案 5 :(得分:0)

如果给定的答案对您不起作用,请确保您没有在语义UI中同时使用引导程序

答案 6 :(得分:0)

快速笔记:

如果未显示下拉列表,并且Bootstrap已使用语义UI在同一页面上加载,则请确保在引导后加载语义js库。

之所以会发生这种情况,是因为引导程序和语义UI都具有用于显示下拉菜单的相同.dropdown()方法。也就是说,在语义UI和引导程序之间加载的最后一个库将覆盖存在的所有其他.dropdown()方法。