首先需要引用jquery-1.7.2.js.

页面下拉框有对应的数据,此下拉框的查询将不与服务器交互。本地下拉框查询。暂不支持通过键盘上下按键和enter键控制


 // JavaScript Document
//使用方法:IniteMyInputSelect('id');IniteMyInputSelect(['id1','id2','id3']);
//id不需要加‘#’,且必须是id
function IniteMyInputSelect(k) {
//如果是数组
if ((typeof (k) == 'object') && k.constructor == Array) {
for (var i = 0; i < k.length; i++) {
$('#' + k[i]).IniteInputSelect();
}
}
else if ((typeof (k) == 'string') && k.constructor == String) {
$('#' + k).IniteInputSelect();
}
}
$(function ($) {
$.fn.IniteInputSelect = function () {
$(this).click(function () {
var id = $(this).attr('id');
var inputid = id + '_input';
var contentid = id + '_content';
var contentdivid = contentid + ' div';
var idoptionid = id + ' option';
var position = $(this).position();
var wd = parseInt($(this).css('width')) + 20;
var input = "<input id='" + inputid + "' type='text' style='" + $(this).attr('style') + "' class='" + $(this).attr('class') + "' /><div id='" + contentid + "' style='position:absolute;z-index:1010;width:" + wd + "px; height:220px; border:1px solid #CCC; background:#FFF;overflow-x:hidden;overflow-y:auto;left:" + position.left + "px; '></div>";
//创建一个input标签给用户输入
$(this).after(input);
$(this).hide();
$('#' + inputid).focus();
//注册点击事件
$('#' + contentdivid).live('click', function () {
var v = $(this).attr('value');
$('#' + id).val(v).show().change();
$('#' + contentid).remove();
$('#' + inputid).remove();
})
//注册鼠标移动上去事件
$('#' + contentdivid).live('mouseover', function () {
$(this).css('background', '#cacaca').css('color', 'white'); })
//注册鼠标移出事件
$('#' + contentdivid).live('mouseout', function () {
$(this).css('background', '').css('color', 'black');
})
//TODO:有问题需要修改 注册在其他位置点击事件
$(document).click(function (e) {
var $target = $(e.target);
var clickid = $target.attr('id');
if (!(clickid == id || clickid == inputid || clickid == contentdivid || $target.is('#' + contentdivid) || $target.is('#' + id) || $target.is('#' + inputid) || $target.is('#' + id+" option"))) {
$('#' + id).show();
$('#' + contentid).remove();
$('#' + inputid).remove();
}
});
//筛选结果 开启筛选
$('#' + inputid).keyup(function () {
var v = $(this).val();
$('#' + contentid).html('');
$('#' + idoptionid).each(function () {
if ($(this).html().search(v) > -1 || v == '') {
var ct = $(this).html();
var cv = $(this).attr('value');
$('#' + contentid).append('<div value="' + cv + '" style="height:24px;line-height:24px; overflow:hidden;color:black;padding-left:3px;cursor: pointer;">' + ct + '</div>');
}
}) })
$('#' + inputid).keyup();
}) }
});

浏览器本地下拉框查询选择js的更多相关文章

  1. JS年月日三级联动下拉框日期选择代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. Jquery下拉框左右选择

    1.说明 本文demo实现下拉框左右选择,本文地址:http://www.cnblogs.com/lengzhan/p/6423023.html 2.代码 <!DOCTYPE html PUBL ...

  3. jquery 下拉框左右选择

    html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <ti ...

  4. selenium 显示等待wait.until 常用封装 及下拉框的选择操作等

    from selenium.webdriver.common.by import Byfrom selenium.webdriver.support.ui import WebDriverWait a ...

  5. 使用 JavaScript 中的 document 对象的属性,根据下拉框中选择的属性,更改页面中的字体颜色和背景颜色

    查看本章节 查看作业目录 需求说明: 使用 JavaScript 中的 document 对象的属性,根据下拉框中选择的属性,更改页面中的字体颜色和背景颜色 实现思路: 在页面的 <body&g ...

  6. 利用js取到下拉框中选择的值

    现在的需求是:下拉框中要是选择加盟商让其继续选择学校,要是选择平台管理员则不需要选择学校.隐藏选择下拉列表. 选择枚举值: /// <summary> /// 平台角色 /// </ ...

  7. Js获取下拉框当前选择项的文本和值

    现在有一个Id为AreaId的下拉框,要获取它当前选择项的文本和值有以下方法: <span class="red">* </span> 地       区: ...

  8. jQuery插件实现select下拉框左右选择_交换内容(multiselect2side)

    效果图: 使用jQuery插件---multiselect2side做法: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitio ...

  9. robotframework使用之 下拉框的选择

    选择下拉框有几种方式处理,首先在浏览器F12选择下拉框 1. F12后看见下拉框的源码是<option xxx> <select class="w_60" dat ...

随机推荐

  1. 路由测试-lee

    //get 路由 Route::get('/', 'WelcomeController@index'); Route::get('home', 'HomeController@index'); //路 ...

  2. 对JVM虚拟机中方法区的理解

    因为jdk8的jvm已经取消了方法区,所以这边先主要介绍jdk8以下版本中方法区相关内容. 1.虚拟机规范中方法区的概念: 原文链接:http://docs.oracle.com/javase/spe ...

  3. 复习HTML+CSS(4)

    n  HTML颜色表示 网页中的颜色有三种表示方法 颜色单词:blue.green.red.yellow 10进制表示:rgb(255,0,0).rgb(0,255,0).rgb(0,0,255) 1 ...

  4. oracle11.2中分区功能测试之add&amp;split partition对global&amp;local index的影响

    生产库中某些大表的分区异常,需要对现有表进行在线操作,以添加丢失分区,因为是生产库,还是谨慎点好,今天有空,针对add&split分区对global&local索引的影响进行了测试,测 ...

  5. [LeetCode] Find the Closest Palindrome 寻找最近的回文串

    Given an integer n, find the closest integer (not including itself), which is a palindrome. The 'clo ...

  6. 机器学习技法:13 Deep Learning

    Roadmap Deep Neural Network Autoencoder Denoising Autoencoder Principal Component Analysis Summary

  7. 机器学习技法:03 Kernel Support Vector Machine

    Roadmap Kernel Trick Polynomial Kernel Gaussian Kernel Comparison of Kernels Summary

  8. 线段树——codevs 1690 开关灯

    先来一发题目: 1690 开关灯 时间限制: 1 s 空间限制: 128000 KB 题目描述 Description YYX家门前的街上有N(2<=N<=100000)盏路灯,在晚上六点 ...

  9. [HNOI 2003]激光炸弹

    Description 一种新型的激光炸弹,可以摧毁一个边长为R的正方形内的所有的目标.现在地图上有n个目标,用整数,表示目标在地图上的位置,每个目标都有一个价值.激光炸弹的投放是通过卫星定位的,但其 ...

  10. codeforces 868B Race Against Time

    Have you ever tried to explain to the coordinator, why it is eight hours to the contest and not a si ...