Search code examples
javascripthtmlcssoverflow

How to have a text-overflow ellipsis at the beginning of a left-to-right element


I have a list of paths (for lack of a better word, maybe bread crumb trails describes them better). Some of the values are too long to display in their parent so I'm using text-overflow: ellipsis. The problem is that the important information is on the right, so I'd like the ellipsis to appear on the left. Something like this this ascii art:

----------------------------
|first > second > third    |
|...second > third > fourth|
|...fifth > sixth > seventh|
----------------------------

Notice that the first row is short enough so it remains left aligned, but the other two are too long so the ellipsis appears on the left hand side.

I'd prefer a CSS only solution, but JS is fine if it can't be avoided. It's ok if the solution only works in Firefox and Chrome.

EDIT: At this point I'm looking for a work around for the bugs in Chrome that prevent it from rendering properly when a document is mixed RTL and LTR. That was all I really needed from the outset, I just didn't realize it.


Solution

  • I finally had to crack in JavaScript:

    <html>
        <head>
            <style>
                #container {
                    width: 200px;
                    border: 1px solid blue;
                }
    
                #container div {
                    width: 100%;
                    overflow: hidden;
                    white-space: nowrap;
                }
            </style>
            <script>
                function trimRows() {
    
                    var rows = document.getElementById('container').childNodes;
                    for (var i=0, row; row = rows[i]; i++) {
                        if (row.scrollWidth > row.offsetWidth) {
                            var textNode = row.firstChild;
                            var value = '...' + textNode.nodeValue;
                            do {
                                value = '...' + value.substr(4);
                                textNode.nodeValue = value;
    
                            } while (row.scrollWidth > row.offsetWidth);
                        }
                    }
                }
            </script>
        </head>
        <body onload='trimRows();'>
        <div id="container" >
            <div>first > second > third</div>
            <div>second > third > fourth > fifth > sixth</div>
            <div>fifth > sixth > seventh > eighth > ninth</div>​
        </div>
        </body>
    
    </html>
    

    JSFiddle