html (+css): denoting a preferred place for a line break

前端 未结 9 1582
南旧
南旧 2020-11-28 03:08

Let\'s say I have this text that I want to display in an HTML table cell:

Honey Nut Cheerios, Wheat Chex, Grape-Nuts, Rice Krispies, Some random cereal with          


        
相关标签:
9条回答
  • 2020-11-28 03:34

    You can just adjust the margin settings in CSS (margin-right in this case).

    text {
        margin-right: 20%;
    }
    
    0 讨论(0)
  • 2020-11-28 03:40

    An easy answer is to use the zero-width space character ​ It is used for making breakspaces inside words at specific points.

    Does the exact opposite of the non-breaking space   (well, actually the word-joiner ⁠)(word-joiner is the zero-width version of non-breaking space)

    (there are also other non breaking codes like the non-breaking hyphen ‑)(here is an extensive answer on different 'variants' of nbsp)

    If you want an HTML-only (no CSS/JS) solution you could use a combination of the zero-width space and the non-breaking space, however this would be really messy, and writing a human-readable version requires a little effort.

    ctrl + c, ctrl + v helps

    example:

       Honey&nbsp;Nut&nbsp;Cheerios,<!---->&#8203;<!--
    -->Wheat&nbsp;Chex,<!---->&#8203;<!--
    -->Grape&#8209;Nuts,<!---->&#8203;<!--
    -->Rice&nbsp;Krispies,<!---->&#8203;<!--
    -->Some&nbsp;random&nbsp;cereal&nbsp;with&nbsp;a&nbsp;very&nbsp;long&nbsp;name,<!---->&#8203;<!--
    -->Honey&nbsp;Bunches&nbsp;of&nbsp;Oats,<!---->&#8203;<!--
    -->Wheaties,<!---->&#8203;<!--
    -->Special&nbsp;K,<!---->&#8203;<!--
    -->Froot&nbsp;Loops,<!---->&#8203;<!--
    -->Apple&nbsp;Jacks
    

    unreadable? this is the same HTML with no comment tags:

       Honey&nbsp;Nut&nbsp;Cheerios,&#8203;Wheat&nbsp;Chex,&#8203;Grape&#8209;Nuts,&#8203;Rice&nbsp;Krispies,&#8203;Some&nbsp;random&nbsp;cereal&nbsp;with&nbsp;a&nbsp;very&nbsp;long&nbsp;name,&#8203;Honey&nbsp;Bunches&nbsp;of&nbsp;Oats,&#8203;Wheaties,&#8203;Special&nbsp;K,&#8203;Froot&nbsp;Loops,&#8203;Apple&nbsp;Jacks
    

    However, since email html rendering is not completely standardized, its good for that kind of use since this solution uses no CSS/JS

    Also, if you use this in combination with any of the <span>-based solutions, you will have complete control of the line-breaking algorithm

    (editorial note:)

    The only problem I could see you having is if you wanted to change the points of preferred breakage dynamically. This would require constant JS manipulation of each of the spans proportionate size, and having to handle those HTML entities in the text.

    0 讨论(0)
  • 2020-11-28 03:43

    New answer now we have HTML5:

    HTML5 introduces the <wbr> tag. (It stands for Word Break Opportunity.)

    Adding a <wbr> tells the browser to break there before anywhere else, so it's easy to make words break after commas:

    Honey Nut Cheerios,<wbr> Wheat Chex,<wbr> Grape-Nuts,<wbr> Rice Krispies,<wbr> Some random cereal with a very long name,<wbr> Honey Bunches of Oats,<wbr> Wheaties,<wbr> Special K,<wbr> Froot Loops,<wbr> Apple Jacks
    

    It is supported my all major browsers apart from IE.

    0 讨论(0)
  • 2020-11-28 03:48

    The answer is no (You cannot alter the line breaking algorithm used).

    But there are some workarounds (best one is the accepted answer)

    You can go near with the non-breaking-space &nbsp; but only between words that go together (what you have in spans, but not after the comma ), or you can use the white-space:nowrap as @Marcel mentioned.

    Both solutions do the same thing, and both will not break a group of words if it does not fit on its own.

    0 讨论(0)
  • 2020-11-28 03:49

    By using

    span.avoidwrap { display:inline-block; }
    

    and wrapping the text I want to be kept together in

    <span class="avoidwrap"> Text </span>
    

    it will wrap first in preferred blocks and then in smaller fragments as needed.

    0 讨论(0)
  • 2020-11-28 03:51

    With your mark-up above use span { white-space:nowrap }. It's as good as you can expect really.

    0 讨论(0)
提交回复
热议问题