Как избежать двойных кавычек в атрибуте title

Я пытаюсь использовать строку, содержащую двойные кавычки в атрибуте title якоря. Пока я пробовал:

<a href=".." title="Some \"text\"">Some text</a>
<!-- title looks like `Some \` --!>

и

<a href=".." title="Some &quot;text&quot;">Some text</a>
<!-- title looks like `Some ` --!>

Обратите внимание, что использование одинарных кавычек не является вариантом.

Ответ 1

Этот вариант -

<a href=".." title="Some &quot;text&quot;">Some text</a>

Правильно и работает так, как ожидалось - вы видите обычные кавычки в отображаемой странице.

Ответ 2

РЕДАКТИРОВАТЬ: Ссылка кажется мертвой, поэтому здесь приведен фрагмент escape-символов, снятых с кешированной страницы archive.org:

&#060   |   less than sign  <       
&#064   |   at sign @       
&#093   |   right bracket   ]       
&#123   |   left curly brace    {       
&#125   |   right curly brace   }       
&#133   |   ellipsis    …       
&#135   |   double dagger   ‡       
&#146   |   right single quote  ’       
&#148   |   right double quote  "       
&#150   |   short dash  –       
&#153   |   trademark   ™       
&#162   |   cent sign   ¢       
&#165   |   yen sign    ¥       
&#169   |   copyright sign  ©       
&#172   |   logical not sign    ¬       
&#176   |   degree sign °       
&#178   |   superscript 2   ²       
&#185   |   superscript 1   ¹       
&#188   |   fraction 1/4    ¼       
&#190   |   fraction 3/4    ¾       
&#247   |   division sign   ÷       
&#8221  |   right double quote  "       
&#062   |   greater than sign   >   
&#091   |   left bracket    [   
&#096   |   back apostrophe `   
&#124   |   vertical bar    |   
&#126   |   tilde   ~   
&#134   |   dagger  †   
&#145   |   left single quote   ‘       
&#147   |   left double quote   "   
&#149   |   bullet  •   
&#151   |   longer dash —   
&#161   |   inverted excallamation point    ¡   
&#163   |   pound sign  £   
&#166   |   broken vertical bar ¦   
&#171   |   double left than sign   «   
&#174   |   registered trademark sign   ®   
&#177   |   plus or minus sign  ±   
&#179   |   superscript 3   ³   
&#187   |   double greather than sign   »   
&#189   |   fraction 1/2    ½   
&#191   |   inverted question mark  ¿   
&#8220  |   left double quote   "   
&#8212  |   dash    —   

/EDIT

Сделайте снимок

Список символов Escape HTML.

Это отличная ссылка для всех этих символов.

Ответ 3

Работает ли &#34; вместо &quot;?

Ответ 4

Использование &quot; - это способ сделать это, я попробовал второй фрагмент кода, и он работает как с Firefox, так и с IE.

Ответ 5

Он может работать с любым символом из списка символов HTML Escape, но у меня была такая же проблема с проектом Java. Я использовал StringEscapeUtils.escapeHTML("Testing \" <br> <p>"), а заголовок был <a href=".." title="Test&quot; &lt;br&gt; &lt;p&gt;">Testing</a>.

Он работал только для меня, когда я изменил StringEscapeUtils на StringEscapeUtils.escapeJavascript("Testing \" <br> <p>") и работал в каждом браузере.

Ответ 6

Существует, по крайней мере, одна ситуация, когда использование одиночных кавычек не будет работать, а именно, если вы создаете разметку "на лету" из Javascript. Вы используете одиночные кавычки, чтобы содержать строку, а затем любое свойство разметки может иметь двойные кавычки для своего значения.

Ответ 7

Возможно, вы можете использовать JavaScript для решения кроссбраузерной проблемы. Он использует другой механизм возврата, тот, с которым вы, очевидно, уже знакомы:

(reference-to-the-tag).title = "Some \"text\"";

Он строго не разделяет функции HTML, JS и CSS так, как люди хотят вас сейчас, но кому вам нужно радоваться? Ваши пользователи или технари, которых вы не знаете?

Ответ 8

Вы можете использовать этот код PHP для отображения специальных символов...

<table border="1"><?php for($i=33;$i<9000;$i++)echo "<tr><td>&#38;#$i;<td>&#".$i.";"; ?></table>