firefoxとIEでうまく動作するサイズ変更可能なdivのコードを見つけましたが(書かれていません)、Chromeでは非常に展開が難しいです。あなたはそれを伸ばそうとします。私はこれがなぜなのかも分からない。トラブルシューティングが難しい。ユーザー入力のクロムの動的divの高さ
chromeが頻繁にこのdivを拡張することを拒否している理由についてのヒントはいいと思います。自分で試してみてください。
#mydiv{
position:relative;
top:0px;
left:0px;
width:250px;
border: 1px solid #808080;
overflow: auto;
}
#statusbar{
cursor: s-resize;
position:relative;
display:block;
background-color: #c0c0c0;
font-size: 0px;
margin:0;
height:5px;
border: 1px solid #808080;
padding:0;
width: 250px;
}
スクリプト:
var curHeight=0;
var curMousePos=0;
var mouseStatus='up';
var curEvent;
//this function gets the original div height
function setPos(e){
curEvent=(typeof event=='undefined'?e:event);
mouseStatus='down';
//gets position of click
curMousePos=curEvent.clientY;
curHeight=parseInt(document.getElementById('mydiv').style.height.split('p')[0]);
}
//this changes the height of the div while the mouse button is depressed
function getPos(e){
if(mouseStatus=='down'){
curEvent=(typeof event=='undefined'?e:event);
//how many px to update the div? difference of previous and current positions
var pxMove=parseInt(curEvent.clientY-curMousePos);
var newHeight=parseInt(curHeight+pxMove);
//conditional to set minimum height to 5
newHeight=(newHeight<5?5:newHeight);
//set the new height of the div
document.getElementById('mydiv').style.height=newHeight+'px';
}
}
ついにHTML:
<div>
<div id="mydiv" style="height: 250px; min-height:150px; ">
<div></div>
</div>
<div onmousedown="setPos(event)" onmouseup="mouseStatus='up'" id="statusbar"></div>
</div>
EDITは:クロームはCSS3プロパティRESIZEをサポートしているようです。これは私が使用したJSのアプローチよりも素晴らしいものです。それでも、上記のコードはFF/IEと同じようにchromeで動作していたので、ブラウザのタイプを確認する必要はありません。
今後の参考のために、あなたは、フォーマットを表示し、それをフォーマットするテキストエリアの上に、 '{}'アイコンをクリックするコードのセクション全体を強調表示することができます。 – Robert