jQuery插件——下拉选择框
其实,之前也写过jQuery插件,今天写的是一个模拟select选择的下拉插件。
既然是jQuery插件,那么必然是依赖jQuery的了。
老规矩,直接上代码吧!
;(function () {
$.fn.extend({
dropdown:function (options) {
return this.each(function (i, val) {
$(val).css("position", "relative");
var oThis = $(this);
// 设置默认参数
var opts = $.extend({
color: "#0a96d4",
items: [
{key1: "选项一"},
{key2: "选项二"},
{key3: "选项三"},
{key4: "选项四"},
{key5: "选项五"}
],
initialVal: "请选择",
callback: function () {
}
}, options);
// 创建默认选择--请选择
var $defaultVal = $("<p class='item'></p>").html(opts.initialVal).appendTo($(this));
oThis.data("val", opts.initialVal);
// 创建选择项
var $items = $("<ul class='menu-options'></ul>");
$(this).append($items);
// 为每一个选择项添加属性 如果是对象类型,则添加key作为属性,如果就是字符串的话,直接既当做属性,也当做内容添加
$.each(opts.items, function (index, item) {
if (typeof item == "string" || typeof item == "number") {
var oLi = $("<li></li>").html(item).attr("data-val", item).appendTo($items);
if (opts.initialVal == item) oLi.addClass("active");
} else if (typeof item == "object") {
for (var key in item) {
var oLi = $("<li></li>").html(item[key]).attr("data-val", key).appendTo($items);
if (opts.initialVal == item[key]) oLi.addClass("active");
}
}
});
$defaultVal.on("click", function (ev) {
ev.stopPropagation();
$(".open").not(this).trigger("click");
$(this).toggleClass("open");
$(this).hasClass("open") ? $(this).next().slideDown() : $(this).next().slideUp()
});
// 选择项的点击事件
$items.on("click", "li", function (ev) {
ev.stopPropagation();
var $this = $(this);
$(this).addClass("active").css("backgroundColor", opts.color).siblings().removeClass("active").css("backgroundColor", $this.parent().css("backgroundColor"));
opts.callback();
$this.parent().slideUp(function () {
$this.parent().prev("p").html($this.html()).add(oThis).attr("data-val", $this.attr("data-val")).removeClass("open");
});
});
// 点击空白部分,关闭下拉选择框
$(window).on("click", function () {
if ($defaultVal.hasClass("open")) {
$defaultVal.trigger("click");
}
})
});
}
})
})(jQuery);
页面上比较干净:
<div class="dropdown"></div>
js部分属于直接调用dropload方法即可:
$(".dropdown").dropdown({
color: "#f0f",
items: [
{"shucai": "青菜"},
{"shuiguo": "葡萄"},
{"food": "面包"}
],
callback: function () {
console.log($(this))
}.bind($(".dropdown"))
});
items数组内容也可以直接是多个字符串,如: ["苹果", "水蜜桃", "哈密瓜"]
jQuery插件——下拉选择框的更多相关文章
- ul+jquery自定义下拉选择框
<!doctype html> <html> <head> <meta charset="UTF-8"> <title> ...
- FancySelect – 更好用的 jQuery 下拉选择框插件
FancySelect 这款插件是 Web 开发中下拉框功能的一个更好的选择.FancySelect 使用方便,只要绑定页面上的任何 Select 元素,并调用就 .fancySelect() 就可以 ...
- jquery.chosen.js下拉选择框美化插件项目实例
由于之前使用的bootstrap-select插件是建立在bootstrap基础上的,实际使用到项目中的时候,与我们使用的ace-admin(基于bootstrap)存在样式冲突,导致下拉框的样式发生 ...
- 基于jQuery美化联动下拉选择框
今天给大家介绍一款基于jQuery美化联动下拉选择框.这款下下拉选择框js里自带了全国所有城市的数数库.下拉选择框适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲 ...
- CSS3不一样的下拉选择框
本例中包含两个下拉选择框的动画示例,本例中并未使用select标签.本例中第一个案例也可用于标题.导航栏等位置. 案例一: html布局 <div class="content&quo ...
- CSS自定义select下拉选择框(不用其他标签模拟)
今天群里有人问到怎么自定义select下拉选择框的样式,于是群里就展开了激烈的讨论,刚开始一直就是考虑怎样使用纯CSS实现,把浏览器默认的样式覆盖掉,但最后均因兼容问题处理不好而失败告终,最后的解决方 ...
- combobox级联检索下拉选择框
1.效果图 2.前端 @{ ViewBag.Title = "Index"; Layout = null; @*自动筛选下拉框*@ <script src="~/S ...
- select2 智能补全模糊查询select2的下拉选择框使用
我们在上篇文章中已经在SpringMVC基础框架的基础上应用了BootStrap的后台框架,在此基础上记录select2的使用. 应用bootstrap模板 基础项目源码下载地址为: SpringMV ...
- java、easyui-combotree树形下拉选择框
最近一直在研究这个树形的下拉选择框,感觉非常的有用,现在整理下来供大家使用: 首先数据库的表架构设计和三级菜单联动的表结构是一样,(父子关系) 1.下面我们用hibernate建一下对应的额实体类: ...
随机推荐
- EXT4 超级块介绍(转)
https://blog.csdn.net/sunlei0625/article/details/79011946 The superblock records various information ...
- dashboard无法查到endpoint, counter
问题 使用Open-falcon时,Agent 推送metrics后,无法在Dashboard上显示.将Agent的hostname 修改后,却可以. 解决办法 查看Agent log,推送到tran ...
- Hadoop数据分析实例:P2P借款人信用风险实时监控模型设计
Hadoop数据分析实例:P2P借款人信用风险实时监控模型设计 一提到hadoop相信熟悉IT领域或者经常关注互联网新闻的朋友都应该很熟悉了,当然,这种熟悉可能也只是听着名字耳熟,但并不知道它具体是什 ...
- 超级账本Hyperledge的kafka共识算法里的Topic 与 Partition
Topic在逻辑上可以被认为是一个queue队列,每条消息都必须指定它的topic,可以简单理解为必须指明把这条消息放进哪个queue里.为 了使得Kafka的吞吐率可以水平扩展,物理上把topic分 ...
- js中return ,return true,return false;区别
js中return:.return true.return false;区别 转:https://www.cnblogs.com/camikehuihui/p/7999537.html 一.返回控制与 ...
- Python3.6+Scrapy爬取知名技术文章网站
爬取分析 伯乐在线已经提供了所有文章的接口,还有下一页的接口,所有我们可以直接爬取一页,再翻页爬. 环境搭建 Windows下安装Python: http://www.cnblogs.com/0bug ...
- CheckFail设计很垃圾
function checkFail(node, onError, fuckIE) { var id = node.src;//检测是否死链 node.onlo ...
- Ubuntu 14.10 下安装伪分布式hive-0.14.0
本地独立模式,MySQL作为元数据库 1 安装环境准备 1.1 安装JDK,在安装hadoop时候已经安装了,参考http://www.cnblogs.com/liuchangchun/p/40972 ...
- WINDOWS和linux下stdcall
__stdcall被这个关键字修饰的函数,其参数都是从右向左通过堆栈传递的(__fastcall 的前面部分由ecx,edx传), 函数调用在返回前要由被调用者清理堆栈.这个关键字主要见于Micros ...
- django报错总结
问题一: dictionary update sequence element #1 has length 3; 2 is required 解决方法: 检查视图函数的render里传的字典