应同事要求,花了半个小时,写了一个简单的选择颜色的下拉框控件,可以控制输入框指示结果颜色

也贴出来,说不定哪天有用

if (typeof jQuery === 'undefined') { throw 'no jquery'; }
(function () {
window.UE_CONTROL_IDX = 0;
$.fn.GetRect = function () {
var r = $(this).get(0).getBoundingClientRect(),
t = document.documentElement.clientTop,
l = document.documentElement.clientLeft;
return {
top: r.top - t,
bottom: r.bottom - t,
left: r.left - l,
right: r.right - l
}
}
'use strict';
window.UEColorCombox || (window.UEColorCombox = {
config: {
isShowTargetColor:false,
data:['red','green','blue','yellow','black','white'],
style: ''
+ '<style id="ue_colorcombox_style">'
+ ' .ue_colorcombox_frame {border:1px solid #999;border-radius:3px;width:120px;height:auto;overflow:hidden;position:absolute;font-size:12px;user-select:none;margin: 0;padding: 3px;background-color:#fff;display:none;z-index:2;}'
+ ' .ue_colorcombox_item {border:none;width:120px;height:16px;line-height:16px;padding:2px;overflow:hidden;cursor:pointer;}'
+ ' .ue_colorcombox_color {border:none;border-radius:3px;width:32px;height:16px;float:left;cursor:pointer;}'
+ ' .ue_colorcombox_text {border:none;border-radius:3px;width:80px;padding-left:6px;height:16px;line-height:16px;float:left;cursor:pointer;}'
+ ' .ue_colorcombox_target {user-select:true;}'
+ '</style>',
},
showCombox: function () {
var cb = this, list = cb.config.data;
cb.colorComboxDom = cb.colorComboxDom || $('<div class="ue_colorcombox_frame"></div>').appendTo($('body'));
if (cb.colorComboxDom.children().length < 1) {
cb.colorComboxDom.html('');
for (var i = 0; i < list.length; i++) {
var bgcolor = (i % 2) == 0 ? '#fff' : '#eee';
cb.colorComboxDom.append('<div class="ue_colorcombox_item" bgc="' + bgcolor + '" style="background:' + bgcolor + ';"><div class="ue_colorcombox_color" style="background:' + list[i] + ';"></div><div class="ue_colorcombox_text">' + list[i] + '</div></div>');
}
}
cb.colorComboxDom.show();
cb.setComboxPosition();
$('.ue_colorcombox_item').off('click').on('click', function () {
var v = $(this).find('.ue_colorcombox_text').html()
if (cb.config.isShowTargetColor) {
cb.target.css('background-color', v)
}
cb.target.html(v).val(v);
cb.colorComboxDom.hide();
});
$('.ue_colorcombox_text').off('mouseenter').on('mouseenter', function () {
$(this).parent().css('background-color', '#ccc');
$(this).css('background-color', '#ccc');
}).off('mouseleave').on('mouseleave', function () {
var bgc = $(this).parent().attr('bgc');
$(this).parent().css('background-color', bgc);
$(this).css('background-color', bgc);
});
$('.ue_colorcombox_color').off('mouseenter').on('mouseenter', function () {
$(this).parent().css('background-color', '#ccc');
$(this).next().css('background-color', '#ccc');
}).off('mouseleave').on('mouseleave', function () {
var bgc = $(this).parent().attr('bgc');
$(this).parent().css('background-color', bgc);
$(this).next().css('background-color', bgc);
});
},
setComboxPosition: function () {
var ww = $(window).width(),
wh = $(window).height(),
bt = $('body').scrollTop(),
bl = $('body').scrollLeft(),
cw = this.colorComboxDom.outerWidth(),
ch = this.colorComboxDom.outerHeight(),
tw = this.target.outerWidth(),
th = this.target.outerHeight(),
rc = this.target.GetRect();
if ((rc.top + th + ch + 5) < wh) {
this.colorComboxDom.css({ top: rc.top + th });
} else {
this.colorComboxDom.css({ top: rc.top - ch });
}
if ((rc.left + cw) > ww) {
this.colorComboxDom.css({ left: (ww - cw) });
} else {
this.colorComboxDom.css({ left: rc.left });
}
},
bind: function (tg, f) {
if ($('#ue_colorcombox_style').length < 1) {
$(this.config.style).appendTo('head');
}
var id = UE_CONTROL_IDX++;
if (this.config.isShowTargetColor) {
tg.css('background-color', tg.val() || tg.html() || 'white')
}
tg.attr('idx', id).attr('tabindex', id).addClass('ue_date_target')
.off('focus').on('focus', function () {
if ($(this).attr('idx') * 1 != UEColorCombox.idx) {
$('.ue_colorcombox_pop[idx=' + UEColorCombox.idx + ']').remove();
}
UEColorCombox.show(this);
});
},
show: function (tg) {
var c = this.config;
this.target = t = $(tg);
this.idx = t.attr('tabindex') * 1;
c.width = c.width || tg.width();
c.height = c.height || tg.height();
this.showCombox();
},
}); $.fn.bindUEColorCombox = function (f) {
UEColorCombox.bind($(this), f);
}; }());
/* 调用示例
<div id="testDate1" style="width:160px; height:30px; border:1px solid #ddd; ">red</div><br />
<input id="testDate2" style="width:160px; height:30px; border:1px solid #ddd;" value="green" />
<script type="text/javascript">
var dt1 = $('#testDate1').bindUEColorCombox('u');
var dt2 = $('#testDate2').bindUEColorCombox('u');
</script>
*/

基于jquery封装的颜色下拉选择框的更多相关文章

  1. 基于jQuery美化联动下拉选择框

    今天给大家介绍一款基于jQuery美化联动下拉选择框.这款下下拉选择框js里自带了全国所有城市的数数库.下拉选择框适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲 ...

  2. FancySelect – 更好用的 jQuery 下拉选择框插件

    FancySelect 这款插件是 Web 开发中下拉框功能的一个更好的选择.FancySelect 使用方便,只要绑定页面上的任何 Select 元素,并调用就 .fancySelect() 就可以 ...

  3. Dropdown.js基于jQuery开发的轻量级下拉框插件

    Dropdown.js 前言 在SPA(Single Page Application)盛行的时代,jQuery插件的轮子正在减少,由于我厂有需求而开发了这个插件.如果觉得本文对您有帮助,请给个赞,以 ...

  4. jquery.chosen.js下拉选择框美化插件项目实例

    由于之前使用的bootstrap-select插件是建立在bootstrap基础上的,实际使用到项目中的时候,与我们使用的ace-admin(基于bootstrap)存在样式冲突,导致下拉框的样式发生 ...

  5. 基于jQuery的input输入框下拉提示层(自动邮箱后缀名)

    基于jQuery的input输入框下拉提示层,方便用户输入邮箱时的提示信息,需要的朋友可以参考下     效果图   // JavaScript Document (function($){ $.fn ...

  6. ul+jquery自定义下拉选择框

    <!doctype html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. jQuery插件——下拉选择框

    其实,之前也写过jQuery插件,今天写的是一个模拟select选择的下拉插件. 既然是jQuery插件,那么必然是依赖jQuery的了. 老规矩,直接上代码吧! ;(function () { $. ...

  8. CSS3不一样的下拉选择框

    本例中包含两个下拉选择框的动画示例,本例中并未使用select标签.本例中第一个案例也可用于标题.导航栏等位置. 案例一: html布局 <div class="content&quo ...

  9. combobox级联检索下拉选择框

    1.效果图 2.前端 @{ ViewBag.Title = "Index"; Layout = null; @*自动筛选下拉框*@ <script src="~/S ...

随机推荐

  1. mac-终端命令

    发现一个比较好点的关于mac终端下命令的解释文档,全文粘贴到这,免得丢了(原文在此): Mac终端 命令行 [一]bash 终端设置      1.环境变量设置首先要知道你使用的Mac OS X是什么 ...

  2. shell 命令集

    shell 常用知识点--------------------------------------- sed 用法 http://www.cnblogs.com/edwardlost/archive/ ...

  3. 转载:最近有两款路由器D-link , Tenda分别被爆出固件中存在后门

    最近有两款路由器分别被爆出固件中存在后门. D-link D-link是台湾公司,成立于1986年,『公司致力于高级网络.宽带.数字.语音和数据通信解决方案的设计.制造和营销,是业界的全球领导者』(官 ...

  4. onethink入门笔记(二)

    5.onethink页面端获得后台服务器传值的方法 1:一般后台通过assign的值前台通过{$value}显示出来; 2:如果需要在js中使用 则可以通过 在js中写 var m = "{ ...

  5. ReactNative win10初体验

    根据RN中文网上的文档搭建环境,有的地方说的不是很清楚,所以小白的我搞了很久,终于搭建成功,这里分享一下 1. java: jdk和jre,我下载的是1.8(因为官方文档上说AndroidStudio ...

  6. 三维场景中使用BillBoard技术

    三维场景中对于渲染效果不是很精致的物体可以使用BillBoard技术实现,使用该技术需要将物体实时朝向摄像机,即计算billboard的旋转矩阵M. 首先根据摄像机位置cameraPos和billBo ...

  7. [C#基础知识] ReadOnly关键字修饰的变量可以修改,只是不能重新分配

    转自:http://www.cnblogs.com/sujiantao/archive/2011/12/19/2289357.html MSDN 官方的解释 readonly 关键字是可以在字段上使用 ...

  8. JUC.Condition学习笔记[附详细源码解析]

    目录 Condition的概念 大体实现流程 I.初始化状态 II.await()操作 III.signal()操作 3个主要方法 Condition的数据结构 线程何时阻塞和释放 await()方法 ...

  9. WLAN频段的选择

    WLAN(无线局域网)通过射频技术,将设备之间互联.当前应用于WLAN组网的有WIFI,蓝牙等.蓝牙工作在2.4GHZ的ISM(工业.科研.医疗)频段,功率等级分为0dBm,10dBm,20dBm:发 ...

  10. [PHP]使用PHPMailer发送带附件并支持HTML内容的邮件

    来源:http://www.helloweba.com/view-blog-205.html PHPMailer是一个封装好的PHP邮件发送类,支持发送HTML内容的电子邮件,以及可以添加附件发送,并 ...