I'm going to be brief because I'm short on time, so I apologize if this isn't as detailed as I'd like it to be.
I have some code:
print("<a href='#'>Some text<sup>®</sup> some more text</a>");
In FF, this works like I would like, the link as a whole is underlined. However in IE, the link is underlined except under the ® where it looks like a symbol above a hyphen and is rather ridiculous looking.
I've tried several suggestions I found on Google, but none of them are very helpful in achieving the desired effect. Adding a border to the bottom is not an option unfortunately. So far the best solution is to break the underline completely at the sup tag with CSS which still leaves it working fine in FF while still looking less silly in IE.
If anyone could help with this it would be most appreciated, I'd rather not go through the site removing <sup>
tags as I've been told I will have to do should I not solve this dilemma.
UPDATE: Went with the sup {"text-decoration:none" } solution, it'll do for now. There are reg marks everywhere, so the whole site would've had to have been updated, which was more trouble than it was worth we all decided. Thanks to those who replied.
The border-bottom solution will place the line under any "p" "q" or "y" instead of through the letters' bottom legs. That is 2px lower than an underline would be.
An alternative is to make the <a> position:relative
make the <sup> position:absolute; top:-3px; text-decoration:none;
add an extra after </sup>
The
<sup>
tag isn't great for things like trademark and reg symbols.I prefer doing it with css:
If you can set up a .reg class:
For:
I made it work like this
Sometimes you're not allowed to add class to a link or wrap it with any element. The situation is not so rare when you need to work with third-party code. BTW, same problem with element too.
In this case you can use something like this:
Use such styling for Chrome (it has same problems like IE, even harder):
Well I agree it looks awful, but it seems to be just the way IE combines underline and superscript. I suggest you go with your CSS plan to remove the underline for
a sup
if you can't cheat with a border. There's an IE only property calledtext-underline-position
but it doesn't have any value which helps here either I'm afraid.For the benefit of anyone who doesn't know already that would be:
Well it is not an elegant solution, basically use a border instead of an underline. You would have to code the color of it based on "Active, Visted, Etc"
Eric