• 基于CSS 和JS的网页SELECT下拉框美化,JQUERY 插件


    最近为公司的网页制做部,开发了一个用于美化网页上select 下拉框的JQUERY插件,拿来与大家分享。

    1.解决了有些select 美化代码,无法触发原有select 控件的onchange 事件问题。

    2.允许多次调用 $("...").selectCss(),以解决Select的options更新后无法同步的问题。

    使用方法如下: 

    代码
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        
    <title>无标题文档</title>
        
    <link href="selectCss.css" rel="stylesheet" type="text/css" />
        
    <script src="jquery-1.3.2.min.js" type="text/javascript"></script>
        
    <script src="selectCss.js" type="text/javascript"></script>
        
    <script type="text/javascript">
             $(document).ready(
    function(){             
                   $(
    "select").selectCss();    
             });
        
    </script>
    </head>
    <body>
       
    <select name="" onchange="alert(this.value)" id="select1">
       
    <option value="1" title="选项选项选项选项" >选项1</option>
       
    <option value="2">选项2</option>
       
    <option value="3">选项3</option>
       
    </select>
          
    <select name="" id="select2">
       
    <option value="1">选项31</option>
       
    <option value="2">选项32</option>
       
    <option value="3">选33</option>
       
    </select>  
    </body>
    </html>

     主要文件包括 selectCss.cssselectCss.js

    selectCss.js 文件代码: 

    代码
      (function($){
         
    function hideOptions(speed){    
             
    if(speed.data){speed=speed.data}
             
    if($(document).data("nowselectoptions"))
             {
                 $($(document).data(
    "nowselectoptions")).slideUp(speed);
                 $($(document).data(
    "nowselectoptions")).prev("div").removeClass("tag_select_open");

                 $(document).data(
    "nowselectoptions",null);
                 $(document).unbind(
    "click",hideOptions);
                 $(document).unbind(
    "keyup",hideOptionsOnEscKey);

             }
             
         }
         
    function hideOptionsOnEscKey(e){
              
            
    var myEvent = e || window.event;
            
    var keyCode = myEvent.keyCode;        
            
    if(keyCode==27)hideOptions(e.data);
         }
         
    function showOptions(speed){         
             $(document).bind(
    "click",speed,hideOptions);
             $(document).bind(
    "keyup",speed,hideOptionsOnEscKey);
             $($(document).data(
    "nowselectoptions")).slideDown(speed);
             $($(document).data(
    "nowselectoptions")).prev("div").addClass("tag_select_open");
         }
         
         
         $.fn.selectCss
    =function(_speed){
                      $(
    this).each(function(){                                        
                                            
                               
    var speed=_speed||"fast";
                               
    if($(this).data("cssobj")){
                                    $($(
    this).data("cssobj")).remove();
                               }
                               $(
    this).hide();
                               
                               
    var divselect  = $("<div></div>").insertAfter(this).addClass("tag_select");
                               $(
    this).data("cssobj",divselect); 
                               
    var divoptions = $("<ul></ul>").insertAfter(divselect).addClass("tag_options").hide();  
                               
                               divselect.click(
    function(e){
                                  
    if($($(document).data("nowselectoptions")).get(0!= $(this).next("ul").get(0)){
                                         hideOptions(speed);
                                  }                    
                                
                                  
    if(!$(this).next("ul").is(":visible"))
                                  {
                                       e.stopPropagation();
                                       $(document).data(
    "nowselectoptions",$(this).next("ul"));
                                       showOptions(speed);                                   
                                  }    
                               
                               });
                                
                                divselect.hover(
    function(){
                                                      
                                    $(
    this).addClass("tag_select_hover");    
                                    
                                }
                                ,
                                
    function(){
                                    $(
    this).removeClass("tag_select_hover");
                                  
                                });
                               
                               $(
    this).change(function(){
                                    
                                     $(
    this).nextAll("ul").children("li:eq("+ $(this)[0].selectedIndex +")").addClass("open_selected").siblings().removeClass("open_selected");       
                                     $(
    this).next("div").html($(this).children("option:eq("+ $(this)[0].selectedIndex +")").text());               
                                                       
                               });
                               
                               $(
    this).children("option").each(function(i){
                                   
    var lioption= $("<li></li>").html($(this).text()).attr("title",$(this).attr("title")).appendTo(divoptions); 
                                   
    if($(this).attr("selected")){                    
                                      lioption.addClass(
    "open_selected");
                                      divselect.html($(
    this).text());
                                   }
                                   lioption.data(
    "option",this);
                                   lioption.click(
    function(){                   
                                      lioption.data(
    "option").selected=true;                                
                                      $(lioption.data(
    "option")).trigger("change",true)
                                               
                                   });
                                   lioption.hover(
                                     
    function(){$(this).addClass("open_hover");},
                                     
    function(){ $(this).removeClass("open_hover");    }
                                    );
                                   
                              });                 
                                             
                      }); 
                    
         }  
      
    })(jQuery);

    selectCss.Css 文件代码: 

    代码
    .tag_select{display:block;color:#000;width:179px;height:23px;background:transparent url("images/index_22.jpg") no-repeat 0 0;padding:0 10px;line-height:23px; color:#7D7D7D; font-size:12px; cursor:pointer}
    .tag_select_hover
    { color:#ff0000; background:transparent url("selectbg.jpg") no-repeat 0 0; }
    .tag_select_open
    { color:#0000ff;  background:transparent url("selectbg.jpg") no-repeat 0 0;}
    ul.tag_options
    {position:absolute;margin:0;list-style:none;background:#fff;padding:0 0 1px;margin:0;width:162px ; height:100px; overflow:hidden; overflow-y:auto; font-size:12px; margin-left:10px; cursor:pointer; z-index:1000 }
    ul.tag_options li
    {background:#fff; display:block;width:140px;padding:0 10px;height:20px;text-decoration:none;line-height:20px;color:#000; font-weight:normal; font-size:12px}
    ul.tag_options li.open_hover
    {background:#0000ff;color:#000; font-weight:normal; font-size:12px}
    ul.tag_options li.open_selected
    {background:#ccc; font-size:12px;font-weight:bold; }

    selectbg.jpg 图片:

     

  • 相关阅读:
    事件冒泡与捕获
    $(this)到底是个啥
    监测代码的作用及用法
    响应消息的内容类型text/html与绑定的text/xml内容类型不匹配
    MySqlConnection using MySql.Data.dll
    mysql 导出导入数据库
    ORA-06550 PLS-00103:出现符号“DROP”在需要下列之一时:
    注册InstallShield Limited Edition for Visual Studio 时无法选择国家解决方法
    访问LINQ的结果
    WPF TextBox中keydown事件组合键
  • 原文地址:https://www.cnblogs.com/bluecoder/p/1862718.html
Copyright © 2020-2023  润新知