ホームページ  >  記事  >  ウェブフロントエンド  >  デフォルトのコンテンツを追加する必要がある HTML のテキストエリア入力ボックス プロンプト テキストに対する完璧なソリューション

デフォルトのコンテンツを追加する必要がある HTML のテキストエリア入力ボックス プロンプト テキストに対する完璧なソリューション

黄舟
黄舟オリジナル
2017-07-19 17:38:5610198ブラウズ


テキストエリア入力ボックスのプロンプトテキストに対する完璧なソリューションです。デフォルトのコンテンツを追加する必要があります

<input> にはプレースホルダータグがあり、プロンプトテキストを追加できますが、 <textarea> code>いいえ、一般的に、以下に示すように、プロンプト コンテンツは <code><textarea></textarea> の外側に記述します: <input>有placeholder标签,可以添加提示文字 ,但是<textarea></textarea>没有,一般来说我们是把提示内容写在<textarea></textarea>外面,如下图:
デフォルトのコンテンツを追加する必要がある HTML のテキストエリア入力ボックス プロンプト テキストに対する完璧なソリューション

当然,这样的布局并不是最想要的效果,
最想要的是文字显示在输入框内,点击输入框时隐藏,离开输入框时,如果输入框没有内容,又显示提示:

网上搜到的都是利用js通过获取或失去焦点来设置textarea的内容,这有个最大的问题就是:因为设置了默认内容,如果用户不点击输入框,直接提交,就把默认的提示内容提交到后台了。

本人想出来的解决方案是:将提示内容写在一个p中,通过css的position属性来控制,将p显示到<textarea></textarea>中,点击<textarea></textarea>デフォルトのコンテンツを追加する必要がある HTML のテキストエリア入力ボックス プロンプト テキストに対する完璧なソリューション
デフォルトのコンテンツを追加する必要がある HTML のテキストエリア入力ボックス プロンプト テキストに対する完璧なソリューションもちろん、そのようなレイアウトは最も望ましい効果ではありません。

私が最も望んでいること入力ボックスにテキストが表示されますが、入力ボックスをクリックすると非表示になります。入力ボックスにコンテンツがない場合は、次のプロンプトが表示されます。 js を使用して、フォーカスの取得または喪失によってテキストエリアのコンテンツを設定します。これには最大の問題があります。問題は、デフォルトのコンテンツが設定されているため、ユーザーが入力ボックスをクリックせずに直接送信すると、デフォルトのプロンプトコンテンツが次のようになります。バックグラウンドに送信されます。
私が思いついた解決策は、プロンプトの内容を p に記述し、CSS の Position 属性で制御し、<textarea></textarea> に p を表示し、<textarea> をクリックします。 </textarea> を p に非表示にすると、ユーザーが入力ボックスをクリックして直接送信しなくても、デフォルトのプロンプト テキストがバックグラウンドに送信されなくなります。その効果は次のとおりです: 🎜🎜🎜
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>解决textarea输入框提示文字,必须添加默认内容</title>
        <style type="text/css">
             body{font-size:12px;}
             p,p{margin:0;padding:0}             
             .textarea{            
             width:350px;height:80px;position:absolute;background:none;z-index:9
            }             
            .note{             
            position:absolute;line-height:20px;padding:3px 5px;            
             }
        </style>
    </head><body>
    <p style="position:relative;">
        <textarea class="textarea" onfocus="document.getElementById(&#39;note&#39;).style.display=&#39;none&#39;" onblur="if(value==&#39;&#39;)document.getElementById(&#39;note&#39;).style.display=&#39;block&#39;"></textarea>
        <p id="note" class="note">
            <font color="#777">在这里写入你对服务商的额外要求,服务商等级,好评率等</font>
        </p>
    </p></body>
 </html>
🎜。 🎜

以上がデフォルトのコンテンツを追加する必要がある HTML のテキストエリア入力ボックス プロンプト テキストに対する完璧なソリューションの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。