Image DropDown v2.3 jQuery下拉菜单美化插件的新特性:
jQuery版本需要大于1.2.6版本。
HTML结构
先来看看原生的select下拉框。
<select name="webmenu" id="webmenu" onchange="showValue(this.value)"> <option value="calendar">Calendar</option> <option value="shopping_cart">Shopping Cart</option> <option value="cd">CD</option> <option value="email" selected="selected">Email</option> <option value="faq">FAQ</option> <option value="games">Games</option> </select>
我们要使用的select下拉框的结构如下:
<select name="webmenu" id="webmenu" onchange="showValue(this.value)"> <option value="calendar" title="icons/icon_calendar.gif">Calendar</option> <option value="shopping_cart" title="icons/icon_cart.gif">Shopping Cart</option> <option value="cd" title="icons/icon_cd.gif">CD</option> <option value="email" selected="selected" title="icons/icon_email.gif">Email</option> <option value="faq" title="icons/icon_faq.gif">FAQ</option> <option value="games" title="icons/icon_games.gif">Games</option> </select>
引入js文件:
<script src="msdropdown/js/jquery-1.3.2.min.js" type="text/javascript"></script> <script src="msdropdown/js/jquery.dd.js" type="text/javascript"></script> <link rel="stylesheet" type="text/css" href="msdropdown/dd.css" />
调用方法:
<script language="javascript"> $(document).ready(function(e) { try { $("body select").msDropDown(); } catch(e) { alert(e.message); } }); </script>
// target only one id $("#combo2").msDropDown(); // target multiple ids $("#combo1, #combo2").msDropDown(); //by wild card $("body select").msDropDown(); //or $("#divid select").msDropDown(); //or $("#formid select").msDropDown();
方法和属性
//convert normal combobox to image comboxbox 1. $("#comboboxid").msDropDown(); //Show/hide icon on title bar. by default its "true"; 2. $("#combo1").msDropDown({showIcon:false}); //Use inline style 3. $("#combo1").msDropDown({style:'background-color:#333, font-size:24px'}); //Visible rows (it would be good if you enter "rowHeight" when using "visibleRows"); 4. $("#combo1").msDropDown({visibleRows:5, rowHeight:23}); 5. $("#combo1").msDropDown({onInit:'callinitmethod'}); //this method will be called when your dropdown is initialized.
如何更改皮肤?
//Multiple skin on same page $("#comboboxid").msDropDown({mainCSS:'dd2'}); //dd2 is your main CSS $("#comboboxid2").msDropDown(); //dd is default;
dd2.css是你定义的css样式。
面向对象
var oDD = $('#comboboxid').msDropDown().data("dd"); oDD.add(new option({text:'lorem', value:'lorem'})); // behavior is same as original dropdown. //or oDD.add({text:'lorem', value:'lorem', title:'images/ok.gif'}); //will add icon too.
函数
var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.open(); //open dropdown var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.close(); //close dropdown var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.remove(index); //remove options var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.form(); //Returns form name var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.set(property, value); //set property var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.get([property]); //get property - get all properties without passing any argument. var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.item([index]); //Returns option item var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.namedItem(nm); //Returns the the named option item from a <select> element. var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.visible([true,false]); //Set or get the visible property var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.disabled(true|false); //Set the disabled property var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.multiple([true|false]); //Set or get the multiple property var oHandler = $('#comboboxid').msDropDown().data("dd"); oHandler.size([true|false]); //Set or get the size property