国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

jQuery插件datalist實現很好看的input下拉列表

2024-05-06 16:23:07
字體:
來源:轉載
供稿:網友

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

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

當被選中的時候(觸發blur焦點)(不管是鼠標還是tab鍵)清空input框并且顯示自定義的下拉列表,然后可以用鍵盤的上下鍵選擇(鼠標當然肯定沒理由不可以啦),單擊鼠標左鍵或者enter鍵將選中的列表的值輸入到input框。

具體的實現代碼如下:

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>問題1</li> 
  24. <li>問題2</li> 
  25. <li>問題3</li> 
  26. <li>問題4</li> 
  27. <li>問題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里面是初始化瀏覽器默認值用的,這里是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插件,實現html5中input元素datalist的效果 
  4. 兼容IE8+,Firefox,Chrome等常見瀏覽器 
  5. */ 
  6.  
  7. ;(function($,window,document,undefined){ //undefinde是真實的undefined,并非參數 
  8. //將可選擇的變量傳遞給方法 
  9.  
  10. //定義構造函數 
  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之類的元素,應該擁有positive:relative屬性,方便datalist定位。 
  27. var input=$(obj).children().eq(0); //input元素 
  28. var inputUl=$(obj).children().eq(1); //datalist元素 
  29. //設置彈出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變為空,也可以改為某個默認值 
  47. //datalist的顯示和隱藏 
  48. $(input).focus(function() { 
  49. if($(this).val()!=""){ 
  50. $(this).val(""); 
  51. $(inputUl).slideDown(500); 
  52.  
  53. var n=-1; //記錄位置,-1表示未選中。當n=-1時直接按enter瀏覽器默認為倒數第一個 
  54. $(document).keydown(function(event) { 
  55. /* 點擊鍵盤上下鍵,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. //去掉瀏覽器默認 
  79. function stopDefaultAndBubble(e){ 
  80. e=e||window.event; 
  81. //阻止默認行為 
  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對象 
  101. $.fn.myDatalist=function(options){ 
  102. //創建實體 
  103. var datalist=new Datalist(this,options); 
  104. //調用其方法 
  105. return datalist.showList(); 
  106.  
  107. })(jQuery,window,document); 

這里用ul li列表模擬datalist options。實現邏輯非常簡單,稍微需要注意點的是div.input_wrap是用相對定位的,方便ul.input1_ul相對進行定位。由于需求有很多的輸入框且相互之間不影響,因此這里是input1。好歹是我自己開發的第一個插件,mark一記。

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

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 鄢陵县| 大关县| 鄢陵县| 资溪县| 富川| 阿坝| 凌云县| 乐安县| 孝义市| 金乡县| 海盐县| 海安县| 平舆县| 满城县| 景东| 山阳县| 惠水县| 巴楚县| 徐水县| 花莲市| 丁青县| 玉树县| 三明市| 吴江市| 名山县| 汉寿县| 龙海市| 湾仔区| 古交市| 东港市| 石景山区| 巴中市| 丹江口市| 东乡族自治县| 文安县| 民和| 福建省| 新余市| 高要市| 北京市| 明光市|