我試圖創建一個通用函數,我可以從多個位置調用遞歸截斷長文本以適應預定義像素寬度 - 使用jquery。當傳遞整數時,截斷寬度函數不起作用
這裏是代碼...
function constrain(text, original, ideal_width){
var ideal = parseInt(ideal_width);
$('span.temp_item').remove();
var temp_item = ('<span class="temp_item" style="display:none">'+ text +'</span>');
var item_length = text.length;
$(temp_item).appendTo('body');
var item_width = $('span.temp_item').width();
if (item_width > ideal) {
var smaller_text = text.substr(0, (item_length-1));
return constrain(smaller_text, original);
} else if (item_length != original) {
return (text + '…');
} else if (item_length == original) {
return text;
}
}
如果我像這樣運行功能:
$('.service_link span:odd').each(function(){
var item_text = $(this).text();
var original_length = item_text.length;
var constrained = constrain(item_text, original_length,'175');
$(this).html(constrained);
});
文本不會截斷。我也嘗試了175沒有引號。
如果我定義var ideal = 175;在函數內部,那麼它的工作原理。爲什麼傳遞175的函數不工作?如果它是一個字符串,我對它做了一個parseInt。
另外 - 這個截斷代碼在舊機器上運行速度有點慢 - 有關加速它的任何提示?
謝謝!
您能得到什麼,如果你警覺上述下方parseInt函數和警報(理想)(ideal_width)? – 2009-05-21 22:05:11
現在工作後,我通過理想的寬度「返回約束(smaller_text,原始);」 但是,速度問題仍然存在...... – novon 2009-05-21 22:16:21