私のコンテンツが私のdivをオーバーフローするときを知る必要があります。そうであれば、私はすべてのコンテンツを含む新しいウィンドウでページを開くためのリンクに配置されます。コンテンツがオーバーフローするかどうかを確認してください。
乾杯、
DalexL
私のコンテンツが私のdivをオーバーフローするときを知る必要があります。そうであれば、私はすべてのコンテンツを含む新しいウィンドウでページを開くためのリンクに配置されます。コンテンツがオーバーフローするかどうかを確認してください。
乾杯、
DalexL
この幅と高さに合わせるテキストのためのjQueryプラグイン:
(function($) {
$.fn.fitText = function(options) {
options = $.extend({
width: 0,
height: 0
}, options);
$(this).each(function() {
var elem = $(this);
if (options.height > 0) {
while (elem.height() > options.height) {
elem.text(elem.text().substring(0, (elem.text().length - 4)) + 'YourLink');
}
}
if (options.width > 0) {
while (elem.width() > options.width) {
elem.text(elem.text().substring(0, (elem.text().length - 4)) + 'YourLink');
}
}
});
}
})(jQuery);
あなたは、このような構造を作成する場合:
<div id="outer" style="overflow: auto">
<div id="inner">
content
</div>
</div>
inner
の幅または高さがouter
の外側はの寸法を前提としているためという超えたときにオーバーフローが発生しましたビューポートとインナーは、すべてのコンテンツを表示するのに必要な最小の幅と高さを想定しています。
outer
をvisibility: hidden
とマークするとレイアウトできますが表示されません。
コンテンツにposition: fixed
のコンテンツが含まれている場合、その部分は考慮されません(CSS 2はクリップされません)。
質問はJavascriptとしてタグ付けされました! – Gerben
@Gerben、展開してください。この質問は、DIVのHTMLコンテンツについて明らかに話しています。最初のタグはどのようにjavascriptに関連していますか? –
とMarquee Text When Text Overflows:
$('div').each(function(){
var $this = $(this);
if ($this.get(0).scrollHeight > $this.height()) {
$this.after('<a href="#" target="new">Read More</a>');
}
});
これは受け入れられた答えとは異なり、この質問に答えます。私のためにすぐに働きました。 –
優れた、スクロールの高さのチェックは考えられませんでした。 – Ripside
パーフェクトできれいな答え –
なしjQueryの答え:
if(elements.scrollHeight > element.clientHeight)
alert('content-overflow')//not to be confused with stackoverflow
IE6とIE7がscrollHeightに間違った値を与えることがあるようです。あなたは警告しています。 – Gerben
これは助けるかもしれません:http://stackoverflow.com/questions/835684/marquee-text-when-text-overflows –