自写Jquery插件 Combobox
原创文章,转载请注明出处,https://www.cnblogs.com/GaoAnLee/p/9092421.html
上效果

html
<span id='combobox' class='combobox'>城市</span>
<span id='combobox1' class='combobox'>城市</span>
css
@CHARSET "UTF-8";
body, html {
height: 100%;
} ul, li {
list-style: none;
} .combobox {
-webkit-border-radius: 5px 5px;
-moz-border-radius: 5px 5px;
-ms-border-radius: 5px 5px;
-o-border-radius: 5px 5px;
border-radius: 5px 5px;
display: inline-block;
} .combobox+i, #dropdown-list {
position: absolute;
} .combobox, #dropdown-list {
border: 1px solid #AAAAAA;
} .combobox, #dropdown-list>li {
text-align: left;
padding: 0 10px;
} .combobox, .combobox+i, #dropdown-list>li {
cursor: pointer;
font-size: 13px;
} #dropdown-list {
display: none;
} #dropdown-list>li {
color: #ffffff;
background-color: #42485b;
display: block;
}
jquery.combobox.js
/*
* combobox
* authoer:GaoAnLee
* <b id='combobox'></b>
*/
;
(function($, window, document, undefined) {
function _init(combobox, b, options) {
var _this = combobox.element;
var obj = document.getElementById(options.id);
var r = new Array();
if (b) {
_this.css('width', options.width).css('height', options.height).css('line-height', options.height + 'px');
r['x'] = _this.position().top;
r['y'] = _this.position().left;
var t = {
'height': _this.outerHeight(),
'width': _this.outerWidth()
};
_this.parent().css('position', 'relative');
_this.after('<i class=\"fa fa-caret-down dropdown-icon\"></i>');
$(options.combobox).next().css('left', r['y'] + t.width - 30).css('top', r['x'] + 8);
warpList(options, r, t);
}
actions(options);
} function warpList(options, r, t) {
var len = options.list.length;
var buffer = '';
buffer += '<ul id=\"dropdown-list\">';
for (var i = 0; i < len; i++) {
buffer += '<li>' + options.list[i] + '</li>';
}
buffer += '</ul>';
$(options.combobox).next().after(buffer);
$(options.combobox).next().next().css('left', r['y'] + 2).css('top', r['x'] + t.height - 1);
$(options.combobox).next().next().children('li').css('width', options.width + 1).css('height', options.height).css('line-height', options.height + 'px');
} function actions(options) {
$(options.combobox).on('click', function(event) {
var value = $(options.combobox).next().next().css('display');
if (value == 'block') {
$(options.combobox).css('border-radius', '5px 5px 5px 5px');
$(options.combobox).next().next().slideUp('fast');
} else {
$(options.combobox).css('border-radius', '5px 5px 0 0');
$(options.combobox).next().next().slideDown('fast');
}
event.stopPropagation(); //关键在于阻止冒泡
});
$(options.combobox).next().on('click', function(event) {
var value = $(options.combobox).next().next().css('display');
if (value == 'block') {
$(options.combobox).css('border-radius', '5px 5px 5px 5px');
$(options.combobox).next().next().slideUp('fast');
} else {
$(options.combobox).css('border-radius', '5px 5px 0 0');
$(options.combobox).next().next().slideDown('fast');
}
event.stopPropagation(); //关键在于阻止冒泡
});
$(options.combobox).next().next().on('mouseover', 'li', function() {
$(this).css('background-color', '#00C1DE');
});
$(options.combobox).next().next().on('mouseout', 'li', function() {
$(this).css('background-color', '#42485b');
});
$(options.combobox).next().next().on('click', 'li', function() {
var value = $(this).html();
$(options.combobox).html(value);
$(options.combobox).next().next().slideUp('fast');
});
$(document).on('click', function() {
$(options.combobox).css('border-radius', '5px 5px 5px 5px');
$(options.combobox).next().next().slideUp('fast');
});
}
var Combobox = function(e, options) {
this.element = e,
this.defaults = {
width: 100,
height: 30,
combobox: '#combobox',
id: 'combobox'
},
this.options = $.extend({}, this.defaults.options);
};
Combobox.prototype = { };
$.fn.myCombobox = function(target, parm) {
var combobox = new Combobox(this, target);
var options = {};
if (typeof target == 'string' && typeof parm == 'string') {
return combobox[target](parm);
}
if (typeof target == 'string' && typeof parm == 'object') {
options = $.extend({}, combobox.defaluts, parm);
return combobox[target](options);
}
var state = $.data(this, target.id);
if (state) {
options = $.extend({}, state.options, target);
} else {
options = $.extend({}, combobox.defaluts, target);
}
$.data(this, target.id, {
options: options
});
this.each(function() {
_init(combobox, true, options);
});
};
})(jQuery, window, document); $(function() {
var list = ['北京', '上海', '深圳', '广州', '厦门', '杭州', '成都', '重庆'];
$('#combobox').myCombobox({
list: list, //必填
width: 100,
height: 30,
combobox: '#combobox', //必填
id: 'combobox' //必填
}); //加载启动
$('#combobox1').myCombobox({
list: list, //必填
width: 100,
height: 30,
combobox: '#combobox1',
id: 'combobox1'
}); //加载启动 });
自写Jquery插件 Combobox的更多相关文章
- 自己写jquery插件之模版插件高级篇(一)
需求场景 最近项目改版中,发现很多地方有这样一个操作(见下图gif动画演示),很多地方都有用到.这里不讨论它的用户体验怎么样. 仅仅是从复用的角度,如果每个页面都去写text和select元素,两个b ...
- 写JQuery插件的基本知识
普及JQuery知识 知识1:用JQuery写插件时,最核心的方法有如下两个: 复制代码 代码如下: $.extend(object) 可以理解为JQuery 添加一个静态方法. $.fn.exten ...
- [原创作品]手把手教你怎么写jQuery插件
这次随笔,向大家介绍如何编写jQuery插件.啰嗦一下,很希望各位IT界的‘攻城狮’们能和大家一起分享,一起成长.点击左边我头像下边的“加入qq群”,一起分享,一起交流,当然,可以一起吹水.哈,不废话 ...
- 写jQuery插件时,一种更好的合并参数的方法
看到很多人写jQuery插件时居然这样合并参数: this.defaults = { 'color': 'red', 'fontSize': '12px', 'textDecoration':'non ...
- 写JQuery 插件
什么?你还不会写JQuery 插件 前言 如今做web开发,jquery 几乎是必不可少的,就连vs神器在2010版本开始将Jquery 及ui 内置web项目里了.至于使用jquery好处这里就不再 ...
- 锋利的jQuery--编写jQuery插件(读书笔记五)[完结篇]
1.表单验证插件Validation 2.表单插件Form 3.动态事件绑定插件livequery 可以为后来的元素绑定事件 类似于jQuery中的live()方法 4.jQuer ...
- 什么?你还不会写JQuery 插件
前言 如今做web开发,jquery 几乎是必不可少的,就连vs神器在2010版本开始将Jquery 及ui 内置web项目里了.至于使用jquery好处这里就不再赘述了,用过的都知道.今天我们来讨论 ...
- 写JQuery 插件 什么?你还不会写JQuery 插件
http://www.cnblogs.com/Leo_wl/p/3409083.html 前言 如今做web开发,jquery 几乎是必不可少的,就连vs神器在2010版本开始将Jquery 及ui ...
- 第一次写jquery插件,来个countdown计时器吧
之前同学做个购物商城秒杀活动需要计时器的功能,在用jquery提供的countdown插件时,一直报错,貌似还需要依赖除jquery之外的其他插件,搞了半天也没搞成功,就叫我帮忙写个.然而我并没有写过 ...
随机推荐
- PHP的类,abstract类,interface及关键字extends和implements
原文:https://blog.csdn.net/qq_19557947/article/details/77880757?locationNum=4&fps=1 PHP类 PHP类是单继承, ...
- golang 中 channel 的非阻塞访问方法
在golang中,基本的channel读写操作都是阻塞的,如果你想要非阻塞的,可以使用如下示例: 即只要在select中加入default,阻塞立即变成非阻塞: package main import ...
- logging日志模块的使用
logging日志模块的使用 logging模块中有5个日志级别: debug 10 info 20 warning 30 error 40 critical 50 通常使用日志模块,是用字典进行配置 ...
- Java 基础 面向对象修饰符和自定义数据类型
不同修饰符使用细节 常用来修饰类.方法.变量的修饰符如下: public 权限修饰符,公共访问, 类,方法,成员变量 protected 权限修饰符,受保护访问, 方法,成员变量 默认什么也不写 也是 ...
- node微信公众号开发--设置自定义菜单
var request = require("request"); const querystring = require("querystring"); re ...
- Python Shell 中敲击方向键显示「^[[C^[[D],问题解决
碰到问题后,在网上搜索. 有帖子建议:yum install -y ncurses-devel,我这个2.7.13版本的在Linux下不行.估计是解决python3.x的方案. 尝试网上建议的,装了 ...
- 从零开始一起学习SLAM | 为啥需要李群与李代数?
很多刚刚接触SLAM的小伙伴在看到李群和李代数这部分的时候,都有点蒙蒙哒,感觉突然到了另外一个世界,很多都不自觉的跳过了,但是这里必须强调一点,这部分在后续SLAM的学习中其实是非常重要的基础,不信你 ...
- 关于double精确度的简单问题
(1)测试TestDouble.java结果 结果:如图,使用double类型的数据进行运算时结果是不准确的. 原因:double类型的数值占用64bit,即64个二进制数,除去最高位表示正负符号的位 ...
- Hello world!(内含自己编写的C语言二叉树同学录)
修改:刷了一段时间的题,水平渐涨,发现同学录真的要做成市面可行的应用的话,应该按学号建立二叉平衡树,红黑树是一个可行的选择. 在同学的推荐下,来到博客园来找志同道合的人交流代码.3个月后参加蓝桥杯 ...
- js控制元素隐藏和显示
原生: 方法一: document.getElementById("idname").style.visibility="hidden"; document.g ...