ホームページ >バックエンド開発 >PHPチュートリアル >JS は自動プロンプトを備えたテキスト ボックス効果を実装します

JS は自動プロンプトを備えたテキスト ボックス効果を実装します

WBOY
WBOYオリジナル
2016-07-25 09:12:451275ブラウズ

2 つの自動プロンプト テキスト ボックス効果の JS 実装コードを共有します。

例 1、AJAX 実装を直接記述します。 クライアント:

  1. 自動プロンプト用の Ajax テキスト ボックス_bbs.it-home.org
  2. body{
  3. font- family:Arial、Helvetica、sans-serif;
  4. font-size:12px; margin:5px;
  5. form{padding:0px;}
  6. /* ユーザー入力ボックスのスタイル* /
  7. フォントファミリー:Arial、ヘルベチカ、サンセリフ;
  8. フォントサイズ:12px; 余白:1px;
  9. #popup;プロンプトボックスの div ブロックのスタイル*/
  10. position:absolute; width:202px;
  11. font-family:Arial、Helvetica、sans-serif; ;
  12. }
  13. #popup.show{
  14. /* プロンプト ボックスの境界線を表示*/
  15. border:1px Solid #004a7e;
  16. }
  17. #popup.hide{
  18. /* プロンプト ボックスの境界線を非表示にする*/
  19. border:none;
  20. }
  21. /* プロンプトボックスのスタイル*/
  22. list-style:none;
  23. li.mouseOver{
  24. background-color:#004a7e; color:#FFFFFF;
  25. li.mouseOut{
  26. background-color:#FFFFFF;
  27. }
  28. var oInputField; //
  29. var oPopDiv が多くの関数で使用されることを考慮すると、これはグローバル変数の形式になります
  30. var xmlHttp;
  31. if(window.ActiveXObject) xmlHttp = new ActiveXObject ("Microsoft. ].colors;
  32. oPopDiv = document.getElementById("popup");
  33. oColorsUl = document.getElementById("colors_ul");
  34. }
  35. function clearColors(){
  36. //プロンプトをクリアコンテンツ
  37. for(var i=oColorsUl.childNodes.length-1;i>=0;i--)
  38. oColorsUl.removeChild(oColorsUl.childNodes[i]);
  39. oPopDiv.className = "隠す"; setColors(the_colors){
  40. //プロンプト ボックスを表示します。渡されるパラメーターは一致する結果の配列です
  41. clearColors(); //文字を入力するたびに、続行する前に元のプロンプトをクリアします
  42. oPopDiv.className = "show" ;
  43. var oLi;
  44. for(var i=0;i// 一致するプロンプト結果を 1 つずつユーザーに表示します
  45. oLi = document.createElement("li"); appendChild(oLi);
  46. oLi .appendChild(document.createTextNode(the_colors[i]));
  47. oLi.onmouseover = function(){
  48. this.className = "mouseOver"; // マウスが上を通過したときに強調表示します
  49. oLi.onmouseout = function(){
  50. this.className = "mouseOut"; //終了時に元の状態に戻す
  51. }
  52. oLi.onclick = function(){
  53. //ユーザーが一致する項目をクリックすると、入力ボックスを item の値に設定します
  54. oInputField.value = this.firstChild.nodeValue;
  55. clearColors(); //同時にプロンプ​​トボックスをクリアします
  56. }
  57. }
  58. }
  59. function findColors(){
  60. initVars( ); //変数を初期化します
  61. if(oInputField.value.length > 0) {
  62. createXMLHttpRequest() //ユーザー入力をサーバーに送信します
  63. var sUrl = "9-10.aspx?sColor=" + oInputField.value + "×tamp= + new Date().getTime();
  64. xmlHttp .open("GET",sUrl,true);
  65. xmlHttp.onreadystatechange = function(){
  66. if(xmlHttp.readyState == 4 && xmlHttp) .status == 200){
  67. var aResult = new Array();
  68. if (xmlHttp.responseText.length){
  69. aResult = xmlHttp.responseText.split(",") //サーバーを表示results
  70. } bbs.it-home.org
  71. else
  72. clearColors();
  73. }
  74. }
  75. xmlHttp.send(null); // 入力がない場合はプロンプト ボックスをクリアします (たとえば、ユーザーは del キーを押します)
  76. input type="text" name="colors" id="colors" onkeyup="findColors(); / >
  77. /html>
  78. 服务器端(9-10.aspx ):

    1. <%@ Page Language="C#" ContentType="text/html" ResponseEncoding="gb2312" %>
    2. <%@ Import Namespace="System.Data" %>
    3. Response.CacheControl = "キャッシュなし";
    4. Response.AddHeader("プラグマ","キャッシュなし");
    5. string sInput = Request["sColor"].Trim();
    6. if(sInput.Length == 0)
    7. return;
    8. 文字列 sResult = "";
    9. string[] aColors = new string[]{"アリスブルー"、"アンティークウィズ"、"アクアマリン"、"アズール"、"ベージュ"、"ビスク"、"ブラック"、"ブランシュアーモンド"、"ブルー"、"ブルーバイオレット" 、「真鍮」、
    10. 「ブロンズ」、「ブラウン」、「バーリーウッド」、「カデットブルー」、「シャルトルーズ」、「チョコレート」、「銅」、「コーラル」、「コーンフラワーブルー」、「コーンシルク」、「シアン」、
    11. 「ダークブルー」、「ダークシアン」、「ダークゴールデンロッド」、「ダークグレー」、「ダークグリーン」、「ダークキ」、「ダークマゼンタ」、「ダークライブグリーン」、「ダークオーキッド」、
    12. 「ダークレンゲ」、「ダークレッド」、「ダークサーモン」、 "darkseagreen"、"darkslateblue"、"darkslategray"、"darkturquoise"、"darkviolet"、"deeppink"、
    13. "deepskyblue"、"dimgray"、"dodgerblue"、"feldspar"、"firebrick"、"floralwhite"、"フォレストグリーン"、"フクシア"、"ゲインズボロ"、"ゴールド"、"ゴールデンロッド"、
    14. "ゴーレンロッド"、"ゴストホワイト"、"グレー"、"グリーン"、"グリーンイエロー"、"ハニーデュー"、"ホットピンク"、"インディアンレッド" "、"イネン"、"アイボリー"、"カーキ"、"ラベンダー"、
    15. "ラベンダーブラッシュ"、"ローングリーン"、"レモンシフォン"、"ライトブルー"、"ライトコーラル"、"ライトシアン"、"ライトゴーデンロッド"、"ライトゴーデンロッドイエロー" 、"ライトグレー"、
    16. "ライトグリーン"、"ライトピンク"、"ライトサーモン"、"ライトシーグリーン"、"ライトスカイブルー"、"ライトスレートブルー"、"ライトスレートグレー"、"ライトスチールブルー"、"ライトイエロー"、
    17. "ライム"、"ライムグリーン" ,"magenta","magenta","maroom","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurpul",
    18. "mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise", 「ミディアムバイオレットレッド」、「ミッドナイトブルー」、「ミントクリーム」、
    19. 「ミスティローズ」、「モカシン」、「ナバホホワイト」、「ネイビー」、「ネイビーブルー」、「オールドレース」、「オリーブドラブ」、「オレンジ」、「オーキッド」、」オレンジ」、「パレゴデンロッド」、
    20. 「ペールグリーン」、「ペールターコイズ」、「パレビオレレッド」、「パパイヤホイップ」、「ピーチパフ」、「ペルー」、「ピンク」、「プラム」、「パウダーブルー」、「パープル」、「クォーツ」 "、"レッド"、
    21. "ロージーブラウン"、"ロイヤルブルー"、"サドルブラウン"、"サーモン"、"サンディブラウン"、"スカーレット"、"シーグリーン"、"貝殻"、"シエナ"、"シルバー"、"スカイブルー" 、「スレートグレー」、
    22. 「スノー」、「スプリンググリーン」、「スティールブルー」、「タン」、「アザミ」、「トマト」、「ターコイズ」、「バイオレット」、「バイオレットレッド」、「ウィート」、「ホワイトスモーク」、 "黄","黄緑"};
    23. for(int i=0;iif(aColors[i].IndexOf(sInput) == 0)
    24. sResult += aColors[i] + ",";
    25. }
    26. if(sResult.Length>0) //如果有一致项
    27. sResult = sResult.Substring(0,sResult.Length-1); //去掉最後の“,”号
    28. Response.Write(sResult);
    29. %>
    复制幣

    例 2、jQuery を使用して実装。 クライアント:

    1. jQuery は自動プロンプト テキスト ボックスを実装します<style> </li> <li>font-family:Arial、Helvetica sans-serif; </li> <li>font-size:12px; margin:5px; </li> <li>form{padding:0px; margin:0px;} </li> <li>/* ユーザー入力ボックスのスタイル */ </li> <li>font -family :Arial、Helvetica、sans-serif; </li> <li>font-size:12px; border:1px; </li> <li>width:1px; margin:0px; </li> <li>#popup{ </li> <li>/* ブロック スタイル*/ </li> <li>位置:絶対; 幅:202px; </li> <li>フォントサイズ:12px; </li> <li>左:25px; .show{ </li> <li>/* プロンプト ボックスの境界線を表示します*/ </li> <li>border:1px Solid #004a7e; </li> <li>} </li> <li>/* プロンプト ボックスのスタイル*/ </li> <li>ul{ </li> <li>list-style:none; ; パディング:0px; </li> <li>color:#004a7e; </li> <li>color:#FFFFFF; </li> <li><スクリプト言語="javascript" src="jquery.min.js"></script> </li> <li><script language="javascript"> //多くの関数が使用されることを考慮して </li> <li>var oPopDiv;グローバル変数の形式を取る </li> <li>var oColorsUl; </li> <li>function initVars(){ </li> <li>oInputField = $("#colors"); </li> <li>oColorsUl = $(" # color_ul"); </li> <li>} </li> <li>function clearColors(){ </li> <li>//プロンプトの内容をクリア </li> <li>oColorsUl.empty(); </li> <li>oPopDiv.removeClass("show"); </li> <li>} </li> <li>function setColors(the_colors){ </li> <li>//プロンプト ボックスに渡されるパラメータは、一致した結果の配列です</li> <li>clearColors(); //文字を入力するたびに、続行する前に元のプロンプトをクリアします</li> <li>oPopDiv.addClass("show"); </li> <li>for(var i =0) ;i<the_colors.length;i++) <li>//一致するプロンプト結果をユーザーに 1 つずつ表示します<li>oColorsUl.append($("<li>"+the_colors[i]+"</li>") ) ; </li> <li>oColorsUl.find("li").click(function(){ </li> <li>oInputField.val($(this).text()); </li> <li>clearColors(); </li> <li>}).hover( </li> <li>function(){$ ( this).addClass("mouseOver");}, </li> <li>function(){$(this).removeClass("mouseOver");} </li> <li>); </li> <li>function findColors(){ </li> <li>initVars(); </li> <li>if(oInputField.val().length > 0){ </li> <li>//非同期データを取得 </li> <li>$.get("14-10.aspx",{sColor:oInputField.val()}, </li> <li>function(data) { </li> <li>var aResult = new Array(); </li> <li>if(data.length > 0){ </li> <li>aResult = data.split(","); //サーバーの結果を表示します</li> <li>} bbs.it-home .org</li> <li>else </li> <li>clearColors(); </li> <li>}); </li> <li>} </li> <li>else </li> <li>clearColors(); //入力がない場合 (たとえば、ユーザーが del キーを押した場合) </li> <li>} </li> <li></スクリプト> </li> <li><ボディ> </li> <li><フォームメソッド="post" name="colors" id="colors" onkeyup="findColors() ;" <li></form> </li> <li><ul id="colors_ul"></ul> </li> <li></body> </li> <li></html></li> <li> <li> <li> コードをコピーします</li> <li> <li> <p>服务器端(14-10.aspx ): </p> <div class="blockcode"> <div id="code_yYx"><ol> <li> <li><%@ Page Language="C#" ContentType="text/html" ResponseEncoding="gb2312" %> </li> <li><%@ Import Namespace="System.Data" %> </li> <li>Response.CacheControl = "キャッシュなし"; </li> <li>Response.AddHeader("プラグマ","キャッシュなし"); </li> <li>string sInput = Request["sColor"].Trim(); </li> <li>if(sInput.Length == 0) </li> <li>return; </li> <li>文字列 sResult = ""; </li> <li>string[] aColors = new string[]{"アリスブルー"、"アンティークウィズ"、"アクアマリン"、"アズール"、"ベージュ"、"ビスク"、"ブラック"、"ブランシュアーモンド"、"ブルー"、"ブルーバイオレット" 、「真鍮」、「ブロンズ」、</li> <li>「ブラウン」、「バーリーウッド」、「カデットブルー」、「シャルトルーズ」、「チョコレート」、「銅」、「コーラル」、「コーンフラワーブルー」、「コーンシルク」、「シアン」、 "ダークブルー"、"ダークシアン"、</li> <li>"ダークゴールデンロッド"、"ダークグレー"、"ダークグリーン"、"ダークカーキ"、"ダークマゼンタ"、"ダークライブグリーン"、"ダークオーキッド"、"ダークレンゲ"、"ダークレッド"、"ダークサーモン"、</li> <li> "darkseagreen"、"darkslateblue"、"darkslategray"、"darkturquoise"、"darkviolet"、"deeppink"、"deepskyblue"、"dimgray"、"dodgerblue"、</li> <li>"feldspar"、"firebrick"、"floralwhite"、"フォレストグリーン"、"フクシア"、"ゲインズボロ"、"ゴールド"、"ゴールデンロッド"、"ゴーレンロッド"、"ゴストホワイト"、"グレー"、"グリーン"、</li> <li>"グリーンイエロー"、"ハニーデュー"、"ホットピンク"、"インディアンレッド" "、"イネン"、"アイボリー"、"カーキ"、"ラベンダー"、"ラベンダーブラッシュ"、"ローングリーン"、"レモンシフォン"、</li> <li>"ライトブルー"、"ライトコーラル"、"ライトシアン"、"ライトゴーデンロッド"、"ライトゴーデンロッドイエロー" 、"ライトグレー"、"ライトグリーン"、"ライトピンク"、"ライトサーモン"、</li> <li>"ライトシーグリーン"、"ライトスカイブルー"、"ライトスレートブルー"、"ライトスレートグレー"、"ライトスチールブルー"、"ライトイエロー"、"ライム"、"ライムグリーン"、 "マゼンタ",</li> <li>"マゼンタ","マルーム","マルーン","ミディアムアクアマリン","ミディアムブルー","ミディアムオーキッド","ミディアムパープル","ミディアムシーグリーン",</li> <li>"ミディアムスレートブルー","ミディアムスプリンググリーン","ミディアムターコイズ", "mediumvioletred"、"midnightblue"、"mintcream"、"mistyrose"、</li> <li>"モカシン"、"ナバホホワイト"、"ネイビー"、"ネイビーブルー"、"オールドレース"、"オリーブドラブ"、"オレンジ"、"オーキッド"、"オレンジ」、「パレゴデンロッド」、「ペールグリーン」、</li> <li>「ペールターコイズ」、「パレビオレレッド」、「パパイヤホイップ」、「ピーチパフ」、「ペルー」、「ピンク」、「プラム」、「パウダーブルー」、「パープル」、「クォーツ」 "、"レッド"、"ロージーブラウン"、</li> <li>"ロイヤルブルー"、"サドルブラウン"、"サーモン"、"サンディブラウン"、"スカーレット"、"シーグリーン"、"貝殻"、"シエナ"、"シルバー"、"スカイブルー" 、「スレートグレー」、「スノー」、</li> <li>「スプリンググリーン」、「スチールブルー」、「タン」、「アザミ」、「トマト」、「ターコイズ」、「バイオレット」、「バイオレットレッド」、「ウィート」、「ホワイトスモーク」、 "黄","黄緑"}; </li> <li>for(int i=0;i<acolors.length>if(aColors[i].IndexOf(sInput) == 0) <li>sResult += aColors[i] + ","; </li> <li>} </li> <li>if(sResult.Length>0) //如果有一致项 </li> <li>sResult = sResult.Substring(0,sResult.Length-1); //去掉最後の“,”号 </li> <li>Response.Write(sResult); </li> <li>%></li></acolors.length> </li> </ol></div> <em onclick="copycode($('code_yYx'));">复制發</em> </div> </li> </ol></div></div> </li></the_colors.length> </li> </ol></div></div> </td></tr></table> <div id="comment_9668" class="cm"> </div> <div id="post_rate_div_9668"></div> <br><br></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>声明:</span><div>この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。</div></div></div><div class="nphpSytBox"><span>前の記事:<a class="dBlack" title="PHP 配列は複数条件クエリ PHP 文字列分割を実装します" href="https://m.php.cn/ja/faq/319587.html">PHP 配列は複数条件クエリ PHP 文字列分割を実装します</a></span><span>次の記事:<a class="dBlack" title="PHP 配列は複数条件クエリ PHP 文字列分割を実装します" href="https://m.php.cn/ja/faq/319590.html">PHP 配列は複数条件クエリ PHP 文字列分割を実装します</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>関連記事</h2><em><a href="https://m.php.cn/ja/article.html" class="bBlack"><i>続きを見る</i><b></b></a></em><div class="clear"></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-6t+ed+2i-1n-4w" data-ad-client="ca-pub-5902227090019525" data-ad-slot="8966999616"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><ul class="nphpXgwzList"><li><b></b><a href="https://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/1.html" title="cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法" class="aBlack">cURL を使用して PHP で Get リクエストと Post リクエストを実装する方法</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/2.html" title="正規表現内のすべての式記号 (概要)" class="aBlack">正規表現内のすべての式記号 (概要)</a><div class="clear"></div></li></ul></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="autorelaxed" data-ad-client="ca-pub-5902227090019525" data-ad-slot="5027754603"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!</p></div><div class="footermid"><a href="https://m.php.cn/ja/about/us.html">私たちについて</a><a href="https://m.php.cn/ja/about/disclaimer.html">免責事項</a><a href="https://m.php.cn/ja/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body><!-- Matomo --><script> var _paq = window._paq = window._paq || []; /* tracker methods like "setCustomDimension" should be called before "trackPageView" */ _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u="https://tongji.php.cn/"; _paq.push(['setTrackerUrl', u+'matomo.php']); _paq.push(['setSiteId', '9']); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s); })(); </script><!-- End Matomo Code --></html>