I have a table column that needs to be limited to a certain width – say 100 pixels. At times the text in that column is wider than this and contains no spaces. For example:
a_really_long_string_of_text_like_this_with_no_line_breaks_makes_the_table_unhappy
I would like to calculate the width of text server-side and add an ellipsis after the correct number of characters. The problem is that I don’t have data about the rendered size of the text.
For example, assuming the browser was Firefox 3 and the font was 12px Arial. What would be the width of the letter ‘a’, the width of the letter ‘b’, etc.?
Do you have data showing the pixel width of each character? Or a program to generate it?
I think a clever one-time javascript script could do the trick. But I don’t want to spend time re-inventing the wheel if someone else has already done this. I am surely not the first person to come up against this problem.
This would not only be impossible to do server-side, it would also not make sense. You don’t what browser your client will be using, and you don’t know what font settings on the client side will override whatever styling information you assign to a piece of HTML. You might think that you’re using absolute positioning pixels in your style properties, but the client could simply be ignoring those or using some plugin to zoom everything because the client uses a high-dpi screen.
Using fixed widths is generally a bad idea.