はじめまして。タイトルのとおりです。AngularJSをつかって縦方向に自動リサイズするtextareaのdirectiveをつくっています。textareaにテキストが入力され2行目になると自動でtextareaが縦方向にリサイズされるところまでは実現できたのですが、これをページロード時に実行させるところが上手くいきません。
textareaの初期値が空だとこのコードで大丈夫なのですが、初期値に100文字程度のテキストが格納される前提で、初期値のテキスト量に応じてページロード時にtextareaを自動でリサイズさせておきたいです。よろしくお願いします。
lang
1app.directive('resizeTextarea', function() { 2 return { 3 restrict: 'E', 4 transclude: true, 5 replace: true, 6 template: "<textarea placeholder='...'></textarea>", 7 link: function(scope, element, attrs) { 8 var HEIGHT = 25; 9 var el = angular.element(element[0]) 10 el.css('lineHeight', HEIGHT + "px"); 11 el.css('height', HEIGHT + "px"); 12 13 var resize = function(e) { 14 var textHeight = e.target.scrollHeight; 15 var height = ~~(textHeight / HEIGHT) * HEIGHT 16 el.css('height', height + "px"); 17 }; 18 el.on('input', resize); 19 } 20 } 21});
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/07/08 09:20