zoukankan      html  css  js  c++  java
  • 用js枚举实现简易菜单效果

    用js枚举实现简易菜单效果,左侧显示菜单,右侧显示用户选择的菜单,一图胜千言,还是直接来张效果图吧:


    以下是代码:

    <DOCTYPE html>
    <html>
    <head>
        <title></title>
        <style>
        body{
            color:#333;
            font-size:12px;
        }
        div{
           
             300px;     
            margin: 0 auto;
         
        }
       
        ul{
             80px;
            height:200px;
            background: #ccc;
            list-style:none;
            float: left;
            margin: 10px;
            
        }
      
         li{
             60px;
            height:20px;
            margin:4px;
            background: orange;      
            line-height: 20px;
            text-align: center;
            cursor:pointer;   
        }
        li:hover{
            background:#EE9A00 
        }
        </style>
        <script>
        window.onload=function(){
            var oli=document.getElementById('fa').getElementsByTagName('li');
            var newul=document.getElementById('so');
            var newli=newul.getElementsByTagName('li');
    
            for(var i=0;i<oli.length;i++)
            {
                oli[i].onclick=function(){
                    if(selectfn(this.innerHTML)) //倘若该菜没有被选中,那么添加到用户菜单
                        {
                            var createli=document.createElement('li');
                            createli.innerHTML=this.innerHTML;//改代码放在appendchild之前能提高性能
                            newul.appendChild(createli);   //向用户菜单中加入该节点
                        }
                };
                
            }
    
            function selectfn(text){     //核心函数
                var result=true;
                for(var i=0;i<newli.length;i++)   //遍历用户菜单,与当前菜单做对比,判断是否已经选中
                {
                    if(newli[i].innerHTML==text)  //若对比成功说明已经选中该菜
                    {
                        alert('您已选取:'+newli[i].innerHTML);
                        return false;            
                    }
                    
                }
                return true;
            }
    
        }
       
        </script>
    </head>
    <body>
      
            <div>
                <ul id="fa">
                    <h3>菜单:</h3>
                    <li>鱼香肉丝</li>
                    <li>火爆肥牛</li>
                    <li>水煮肉片</li>
                    <li>麻辣乌鱼</li>
                    <li>五香鸭珍</li>
                    <li>红油牛肚</li>
                </ul>
    
                <ul id="so">
                   <h3>您的选择:</h3>
                </ul>
            </div>
    
            
    </body>
    </html>

    其核心原理就是:点击<li>标签时,用该标签的innerHTML与用户菜单<li>标签的innerHTML循环对比匹配,若没有匹配则说明该标签没有被点击过,那就在用户菜单里添加,若对比成功,说明用户菜单已经有该标签,也就是说已经选择了该菜,那就不再往用户里添加,弹出“已经选择该菜”提示框。



  • 相关阅读:
    三、类的实例方法(阶段三)
    二、类的构造方法(阶段三)
    一、对象与类的区别(阶段三)
    五、数组(阶段二)
    四、(续)流程控制--while for(阶段二)
    四、流程控制--if else和switch(阶段二)
    Java 自带的加密类MessageDigest类(加密MD5和SHA)
    java实现微信扫一扫详解
    springmvc字符编码过滤器CharacterEncodingFilter浅析
    Spring的初始化:org.springframework.web.context.ContextLoaderListener
  • 原文地址:https://www.cnblogs.com/chayangge/p/4288688.html
Copyright © 2011-2022 走看看