How to solve BiDi bracket issues?

前端 未结 4 680
孤独总比滥情好
孤独总比滥情好 2021-01-30 09:00

As you might know some languages are written/read from right to left and we are trying to support some RTL languages. For the web UI using dir=\"rtl\" in html does most of the j

4条回答
  •  情话喂你
    2021-01-30 09:43

    There are many problems here. According to the unicode standard, brackets are neutral, meaning they are not inherently treated as LTR or RTL. They take the direction of their surrounding language. In the examples where it is being incorrectly rendered, the direction of the closing bracket is assumed to be the same as of English, ie LTR.

    1st problem: You tell the browser that the paragraph should be treated to be RTL. The browser finds English inside, which is LTR, so it thinks English is embedded inside an RTL paragraph, and the last character ")" is treated to be RTL. (the surrounding paragraph is RTL).

    2nd problem: There is no problem here, from a simple look at the source code you have provided, it appears you have provided the brackets properly. But in fact, the closing bracket which should be after the RTL text and before the closing

    is actually before the starting RTL text. If you type it properly, it would look wrong (because the text editor you are using assumes the end bracket is LTR according to unicode). To verify this, copy the contents on to your editor, put your cursor at the end of "problem:", and press the right arrow repeatedly and observe the location of the last bracket.

    Without giving much more explaination, here are some examples to get this working:

    
    
      
      Bracket problems with BiDi
    
    
    
      

    Bracket problem no more: hello (world):

    Bracket problem no more: hello (world):

    Bracket problem no more: السلام (عليكم)

    Bracket problem no more: السلام (عليكم)

    Bracket problem no more: السلام (عليكم)

    There are differences in how style="direction: ltr;" works and dir="ltr" works, so I've given examples of both. Also, because I assume you basically need to get your second problem solved, where you majorly have RTL text in an otherwise LTR document, I've provided the last two examples.

    NOTE: If the last two examples are what you are looking for, and you are going to use CSS, the unicode-bidi property is required, and that makes all the difference between working and not working.

提交回复
热议问题