麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

jQuery插件datalist實(shí)現(xiàn)很好看的input下拉列表

2024-05-06 16:23:07
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文給大家分享的是使用jQuery實(shí)現(xiàn)的房HTML5中的一個(gè)好看的input框很好看的下拉列表--datalist,兼容性非常不錯(cuò),這里推薦給大家,有需要的小伙伴可以參考下。

HTML5中定義了一種input框很好看的下拉列表--datalist,然而目前它的支持性并不好(萬(wàn)惡的IE,好在你要漸漸退役了...)。于是最近更據(jù)需求寫(xiě)了一個(gè)小型datalist插件,兼容到IE8(IE7應(yīng)該沒(méi)多少人用了吧?)。實(shí)現(xiàn)的具體需求如下:

當(dāng)被選中的時(shí)候(觸發(fā)blur焦點(diǎn))(不管是鼠標(biāo)還是tab鍵)清空input框并且顯示自定義的下拉列表,然后可以用鍵盤(pán)的上下鍵選擇(鼠標(biāo)當(dāng)然肯定沒(méi)理由不可以啦),單擊鼠標(biāo)左鍵或者enter鍵將選中的列表的值輸入到input框。

具體的實(shí)現(xiàn)代碼如下:

HTML

 

 
  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  5. <meta name="description" content="" /> 
  6. <meta name="keywords" content="" /> 
  7. <meta name="robots" content="index, follow" /> 
  8. <meta name="googlebot" content="index, follow" /> 
  9. <meta name="author" content="codetker" /> 
  10. <title> 表單選中彈出框</title> 
  11. <link href="css/reset.css" type="text/css" rel="Stylesheet" />  
  12. <link href="css/master.css" type="text/css" rel="Stylesheet" />  
  13.  
  14. <script type="text/javascript" src="js/jquery-1.11.0.js"></script> 
  15. </head> 
  16.  
  17. <body> 
  18. <div class="wrap"
  19. <form class="center"
  20. <div class="input_wrap"
  21. <input name="input1" class="input input1" type="text"/> 
  22. <ul class="input1_ul select_list"
  23. <li>問(wèn)題1</li> 
  24. <li>問(wèn)題2</li> 
  25. <li>問(wèn)題3</li> 
  26. <li>問(wèn)題4</li> 
  27. <li>問(wèn)題5</li> 
  28. </ul> 
  29. </div> 
  30. </form> 
  31. </div> 
  32. <script type="text/javascript" src="js/jquery.codetker.datalist.js"></script> 
  33. <script type="text/javascript"
  34. $(document).ready(function(){ 
  35. $(".input_wrap").myDatalist({"bgcolor":"red","widths":1,"heights":1});  
  36. }); 
  37. </script> 
  38. </body> 
  39. </html> 

CSS(reset.css里面是初始化瀏覽器默認(rèn)值用的,這里是style.css)

 

 
  1. .wrap{ margin:0 auto; font-family: "微軟雅黑";font-size: 14px;} 
  2. .center{ margin: 0 auto; width:500px;} 
  3. .input{ margin: 0; padding: 0; /*border:none;*/ width:140px; height: 24px; float:left;} 
  4. .select_list{display: none; position:absolute; z-index: 100;} 
  5. .select_list li{ height:24px; margin: 0; padding: 0; background-color: #fff; cursor: pointer; list-style: none; position:relative;} 
  6. .select_list li:hover{ background-color: red;} 
  7. .input_wrap{ position:relative; } 

JavaScript

 

 
  1. /* 
  2. datalist 0.1  
  3. 自定義datalist插件,實(shí)現(xiàn)html5中input元素datalist的效果 
  4. 兼容IE8+,Firefox,Chrome等常見(jiàn)瀏覽器 
  5. */ 
  6.  
  7. ;(function($,window,document,undefined){ //undefinde是真實(shí)的undefined,并非參數(shù) 
  8. //將可選擇的變量傳遞給方法 
  9.  
  10. //定義構(gòu)造函數(shù) 
  11. var Datalist=function(ele,opt){ 
  12. this.$element=ele; 
  13. this.defaults={ 
  14. 'bgcolor':'green'
  15. 'widths':1, 
  16. 'heights':1 
  17. }, 
  18. this.options=$.extend({}, this.defaults, opt); 
  19. //定義方法 
  20. Datalist.prototype={ 
  21. showList:function(){ 
  22. var color=this.options.bgcolor; 
  23. var width=this.options.widths; 
  24. var height=this.options.heights; //屬性值 
  25.  
  26. var obj=this.$element; //obj為最外層包裹的div之類的元素,應(yīng)該擁有positive:relative屬性,方便datalist定位。 
  27. var input=$(obj).children().eq(0); //input元素 
  28. var inputUl=$(obj).children().eq(1); //datalist元素 
  29. //設(shè)置彈出datalist的大小和樣式 
  30. $(inputUl).css({ 
  31. "top":$(input).outerHeight()+"px"
  32. "width":$(input).outerWidth()*width+"px" 
  33. }); 
  34. $(inputUl).children().css({ 
  35. "width":$(input).outerWidth()*width+"px"
  36. "height":$(input).outerHeight()*height+"px" 
  37. }); 
  38.  
  39. $(inputUl).children('li').mouseover(function() { 
  40. $(this).css("background-color",color); 
  41. $(this).siblings().css("background-color","#fff"); 
  42. }); 
  43. $(inputUl).children('li').mouseout(function() { 
  44. $(this).css("background-color","#fff"); 
  45. }); 
  46. //再次focus變?yōu)榭眨部梢愿臑槟硞€(gè)默認(rèn)值 
  47. //datalist的顯示和隱藏 
  48. $(input).focus(function() { 
  49. if($(this).val()!=""){ 
  50. $(this).val(""); 
  51. $(inputUl).slideDown(500); 
  52.  
  53. var n=-1; //記錄位置,-1表示未選中。當(dāng)n=-1時(shí)直接按enter瀏覽器默認(rèn)為倒數(shù)第一個(gè) 
  54. $(document).keydown(function(event) { 
  55. /* 點(diǎn)擊鍵盤(pán)上下鍵,datalist變化 */ 
  56. stopDefaultAndBubble(event); 
  57. if(event.keyCode==38){//向上按鈕 
  58. if(n==0||n==-1){ 
  59. n=4; 
  60. }else
  61. n--; 
  62. $(inputUl).children('li').eq(n).siblings().mouseout(); 
  63. $(inputUl).children('li').eq(n).mouseover(); 
  64. }else if(event.keyCode==40){//向上按鈕 
  65. if(n==4){ 
  66. n=0; 
  67. }else
  68. n++; 
  69. $(inputUl).children('li').eq(n).siblings().mouseout(); 
  70. $(inputUl).children('li').eq(n).mouseover(); 
  71. }else if(event.keyCode==13){//enter鍵 
  72. $(inputUl).children('li').eq(n).mouseout(); 
  73. $(input).val( $(inputUl).children('li').eq(n).text() ); 
  74. n=-1; 
  75. }); 
  76.  
  77.  
  78. //去掉瀏覽器默認(rèn) 
  79. function stopDefaultAndBubble(e){ 
  80. e=e||window.event; 
  81. //阻止默認(rèn)行為 
  82. if (e.preventDefault) { 
  83. e.preventDefault(); 
  84. e.returnValue=false
  85.  
  86. //阻止冒泡 
  87. if (e.stopPropagation) { 
  88. e.stopPropagation(); 
  89. e.cancelBubble=true
  90.  
  91. }); 
  92. $(input).blur(function() { 
  93. $(inputUl).slideUp(500); 
  94. }); 
  95. $(inputUl).delegate('li''click'function() { 
  96. $(input).val( $(this).text() ); 
  97. }); 
  98.  
  99. return this
  100. //在插件中使用Datalist對(duì)象 
  101. $.fn.myDatalist=function(options){ 
  102. //創(chuàng)建實(shí)體 
  103. var datalist=new Datalist(this,options); 
  104. //調(diào)用其方法 
  105. return datalist.showList(); 
  106.  
  107. })(jQuery,window,document); 

這里用ul li列表模擬datalist options。實(shí)現(xiàn)邏輯非常簡(jiǎn)單,稍微需要注意點(diǎn)的是div.input_wrap是用相對(duì)定位的,方便ul.input1_ul相對(duì)進(jìn)行定位。由于需求有很多的輸入框且相互之間不影響,因此這里是input1。好歹是我自己開(kāi)發(fā)的第一個(gè)插件,mark一記。

需要代碼的可以戳https://github.com/codetker/myDatalist。

以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 91精品国产乱码久久久久久久久 | 久久美女免费视频 | 沉沦的校花奴性郑依婷c到失禁 | 香蕉久久久精品 | 在线小视频国产 | 免费嗨片首页中文字幕 | 2021免费日韩视频网 | 一区二区三区四区高清视频 | 国产精品久久久久久久久久了 | 欧美激情第一区 | 亚洲综合91| 欧美日韩国产一区二区三区在线观看 | 国产精品国产三级国产在线观看 | 亚洲视频观看 | 久久久久久久.comav | 国产xxxx岁13xxxxhd| 黄色av网 | 欧美成人高清视频 | 久久艹艹艹 | 国产一区二区在线免费 | 欧美aaa| 蜜桃视频在线观看免费 | 精品一区二区在线观看视频 | 久久激情免费视频 | 成人免费观看在线视频 | 欧美精品一区二区三区四区 | 免费黄色在线电影 | 黄色网址进入 | av电影手机在线看 | 午夜爽爽爽男女免费观看hd | 久久17| 亚洲第一成人在线观看 | 国产18成人免费视频 | 日韩在线激情 | 激情小说区 | 一级黄色免费观看 | 日韩字幕 | 亚洲成人在线视频网站 | 欧美视频在线观看一区 | 久久久日韩av免费观看下载 | 国产亚洲精品综合一区91555 |