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建一下对应的额实体类: ...
随机推荐
- MongoDB 设置账号和密码
一.安装MongoDB 1.环境配置: i.操作系统:CentOS release 6.8 (Final) [root@iZ2ze2pbbffhmn53ao4tuaZ bin]# cat /etc/r ...
- Linux下安装CollabNetSubversionEdge
1.首先下载CollabNet Subversion,目前最新版本Subversion Edge 5.2.2 (Linux 64-bit),注意下载的时候需要注册下账号,才允许下载: 2.安装Coll ...
- 集群RedHat6.5+JDK1.8+Hadoop2.7.3+Spark2.1.1+zookeeper3.4.6+kafka2.11+flume1.6环境搭建步骤
1.RHEL 6.5系统安装配置图解教程(rhel-server-6.5) 2.在Linux下安装JDK图文解析 3.RedHat6.5上安装Hadoop集群 4.RedHat6.5安装Spark集群 ...
- Tomcat里面的APR配置问题研究
这里,之所以研究这个问题,是因为我们的生产系统Linux环境下的tomcat日志里面,启动信息的地方有这么一个WARNING. INFO: The APR based Apache Tomcat Na ...
- 【java】JDK与JRE的区别
JRE和JDK区别: JDK和JRE提供的服务包: JDK是整个JAVA的核心,JDK包含如下核心组件: ·javac – 编译器 ·jar – 打包工具 ·javadoc – 文档生成器 ·jdb ...
- [转]跳板机Jumpserve的生产环境配置
6.跳板机Jumpserver] Jumpserver是国内一款开源的轻便的跳板机系统,他们的官网:http://www.jumpserver.org/ 使用这款软件意在提高公司内部登录生产环境服 ...
- Git常见使用方法
图参考:http://www.ruanyifeng.com/blog/2014/06/git_remote.html 1.GitLab配置 git config --global user.name ...
- g++编译后中文显示乱码解决方案(c++)
g++编译后中文显示乱码解决方案 环境:Windows 10 专业版 GCC版本:5.3.0 测试代码: 1 #include <iostream> 2 using namespace ...
- 【mysql】索引优化记录
基础知识 Innodb存储引擎 支持行锁 支持事务: Myisam存储引擎 只支持表锁: 不支持事务: 常见索引列表 独立的列 前缀索引(索引选择性) 多列索引(并不是多个单列索引,索引顺序很重要) ...
- webscoket通信初步(一)
只要动手做起来,多投入时间和精力.耐心去研究,以大多人的智商加google,平时遇到的大部分问题我们都是可以自己解决的,大部分的知识我们都是可以掌握的. 我们都知道http协议是单向请求的,无法实现双 ...