折叠(树形导航栏)

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8"/>
  <title>4_竖向折叠导航菜单_1</title>
  <style type="text/css">
    /*全局设定*/
    .nav{position: absolute;top:100px;left: 100px;}
    *{margin: 0;padding: 0;font-size: 14px;font-size: "微软雅黑";}
    ul{list-style: none;}
    .nav a{text-decoration: none;display: block;width: 135px;height: 30px;line-height: 30px;color: #fff;text-align: center;}    
    /*一级列表设定*/
    .a1{font-size: 16px;height: 35px;line-height: 35px;}
    .nav{background-color: #888;}
    .li0{border-top: 2px solid #bbb;}
    .li0:first-child{border: 0;}
    /*二级列表设定*/
    .nav1{display: none;background-color: #bbb;}
    /*伪类*/
    .li0:hover .a1{background-color: #444;font-weight: bold;font-size: 17px;}
    .nav1 a:hover{background-color: #f60;font-weight: bold;font-size: 15px;}
  </style>
</head>
<body>
  <ul class="nav">
    <li class="li0"><a class="a1" href="javascript:myclick1()">草帽海贼团</a>
      <ul class="nav1" id="nav101">
        <li class="li1"><a href="">路飞</a></li>
        <li class="li1"><a href="">索隆</a></li>
        <li class="li1"><a href="">山治</a></li>
      </ul>
    </li>
    <li class="li0"><a class="a1" href="javascript:myclick2()">海军</a>
      <ul class="nav1" id="nav102">
        <li class="li1"><a href="">黄猿</a></li>
        <li class="li1"><a href="">青雉</a></li>
        <li class="li1"><a href="">赤犬</a></li>
      </ul>
    </li>
    <li class="li0"><a class="a1" href="javascript:myclick3()">现任王下七武海</a>
      <ul class="nav1" id="nav103">
        <li class="li1"><a href="">汉库克</a></li>
        <li class="li1"><a href="">米霍克</a></li>
        <li class="li1"><a href=""></a></li>
        <li class="li1"><a href="">巴基</a></li>
        <li class="li1"><a href="">白胡子二世</a></li>

      </ul>
    </li>
    <li class="li0"><a class="a1" href="javascript:myclick4()">革命军</a>
      <ul class="nav1" id="nav104">
        <li class="li1"><a href=""></a></li>
        <li class="li1"><a href="">萨博</a></li>
        <li class="li1"><a href="">人妖王</a></li>
      </ul>
    </li>
    <li class="li0"><a class="a1" href="javascript:myclick5()">现任四皇</a>
      <ul class="nav1" id="nav105">
        <li class="li1"><a href="">香克斯</a></li>
        <li class="li1"><a href="">凯多</a></li>
        <li class="li1"><a href="">玲玲</a></li>
        <li class="li1"><a href="">蒂奇</a></li>

      </ul>
    </li>
  </ul>
  <script>
    var arr2 =document.getElementsByClassName('nav1');
    function allNone(){
      //事件开始的时候的状态
      for(var i = 0 ; i < arr2.length;i++){
        arr2[i].style.display = 'none';
      }
    }
    //单机第一个
    function myclick1(){
      var x = document.getElementById('nav101');
      if(x.style.display=='block'){
        x.style.display = "none";
      }else{
        allNone();
        x.style.display ='block';
      }
    };
    function myclick2(){
      var x = document.getElementById('nav102');
      if(x.style.display=="block"){
        x.style.display = "none";
      }else{
        allNone();
        x.style.display = 'block';
      }
    }
  </script>
  
</body>
</html>

 

转载于:https://www.cnblogs.com/TTTK/p/6297870.html

Qt是一个跨平台的应用程序开发框架,它提供了丰富的组件和工具,用于快速构建现代化的图形用户界面。在Qt中,导航栏可以通过使用树形结构来实现。 树形结构是一种层级结构,常用于表示有父子关系的数据。在导航栏中,使用树形结构可以方便地组织和展示多级菜单或目录。 要实现一个基于树形结构的导航栏,我们可以使用Qt提供的一些相关类和组件。首先,我们可以使用QTreeView组件作为导航栏的主界面。QTreeView是一个用于显示树形结构的可视组件,它可以在其内部生成树形结构的视图。 接下来,我们需要定义一个数据模型来存储和管理树形结构的数据。在Qt中,常用的数据模型类是QStandardItemModel。QStandardItemModel是一个预定义的数据模型,可以用于管理带有父子关系的数据。我们可以通过添加QStandardItem来构建树形结构,并使用setItem方法设置父子关系。 在QTreeView中,我们可以使用setModel方法将QStandardItemModel设置为其数据模型,并使用expandAll方法展开所有节点。我们还可以使用QTreeView的一些信号和槽函数来实现节点的展开和折叠,以及与节点相关的操作。 总结起来,通过利用Qt中的QTreeView和QStandardItemModel,我们可以很方便地实现一个导航栏树形结构。我们可以根据需要添加和管理树形结构的节点,实现导航栏的功能。同时,Qt提供的丰富的UI组件和事件机制,也可以让我们进一步定制和优化导航栏的实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值