洗練された UI のプロトタイプを使用したテキストエリアの自動サイズ設定
ユーザー エクスペリエンスを向上させるには、多くの場合、微妙だが影響力のある詳細に焦点を当てる必要があります。そのような側面の 1 つは、テキストエリアの自動サイズ変更です。これにより、テキストエリアが保持するコンテンツに適応して、スペースの最適な利用と読みやすさを確保できます。
この場合、ユーザーは、固定幅を維持しながらテキストエリアの垂直方向のサイズを自動的に変更することを目的としています。 。水平方向のサイズ変更は、ワードの折り返しや行の長さの変化により難しい場合がありますが、垂直方向のサイズ変更は実行可能でユーザーフレンドリーなソリューションです。
この自動サイズ変更動作を実装するために、彼らはガイダンスを求め、Prototype を使用する実用的なソリューションを見つけました。人気のある JavaScript ライブラリ。提供されているコード スニペットは、このアプローチを示しています。
resizeIt = function() { var str = $('text-area').value; var cols = $('text-area').cols; var linecount = 0; $A(str.split("\n")).each( function(l) { linecount += Math.ceil( l.length / cols ); // Take into account long lines }) $('text-area').rows = linecount + 1; }; Event.observe('text-area', 'keydown', resizeIt ); resizeIt(); //Initial on load
このコードは、改行と長い行を考慮してテキストエリア内のコンテンツの各行を反復処理し、ぴったりとフィットするために必要な行数を計算します。イベント リスナーをアタッチしてキーストロークをキャプチャすることで、テキストの変更に応じてテキストエリアのサイズが継続的に変更され、適応性のあるユーザー中心のエクスペリエンスが提供されます。
この戦略を採用すると、ユーザーの対話が合理化され、不必要なスクロールやスクロールの必要性が減ります。テキスト入力のためのシームレスで視覚的に魅力的なインターフェイスを保証します。
以上がPrototype.js は固定幅を維持しながらテキストエリアを垂直方向に自動サイズ変更するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。