Разве нельзя использовать сущности HTML в атрибуте title? - PullRequest
7 голосов
/ 05 мая 2011

image

Приведенный выше скриншот предоставлен Firefox.Курсор находится над желтым пятном с левой стороны изображения.Это элемент <img> (на самом деле это изображение вместе с картой изображений, содержащей один круговой элемент <area>, но я полагаю, что это различие не имеет значения), которое было создано и стилизовано в JavaScript, включая применение заголовкаатрибут (строится путем вырезания и склеивания строк).Как я могу заставить это вести себя и показывать намеченного персонажа, черточку вместо &ndash;?Это работает для innerHTML (текст "Barrow-In-Furness" в верхнем среднем левом углу - это div, который также был создан с использованием JavaScript, и его набор innerHTML.)

Редактировать: В ответ на вопрос Domenic: Вот функция JavaScript, которая создает и применяет атрибут title (в дополнение к выполнению других заданий):

var StyleLinkMarker = function (LinkNumber, EltA, EltI) {
    var AltText = LocationName[LinkStart[LinkNumber]] +
                  " to " +
                  LocationName[LinkEnd[LinkNumber]];
    if (!EltA) {
        EltA = document.getElementById("link_marker_area" + LinkNumber);
        EltI = document.getElementById("link_marker_img" + LinkNumber);
    }
    if (LinkStatus[LinkNumber] === 9) {
        var CanBuyLinkCode = BoardPreviewMode ? 0 : CanBuyLink(LinkNumber);
        if (CanBuyLinkCode === 0) {
            EltI.src = ImagePath + "icon-buylink-yes.png";
            AltText += " (you can buy this " + LinkAltTextDescription + ")";
        } else {
            EltI.src = ImagePath + "icon-buylink-no.png";
            AltText += " (you cannot buy this " + LinkAltTextDescription;
            AltText += CanBuyLinkCode === 1 ?
                       ", because you aren't connected to it)" :
                       ", because you would have to buy coal from the Demand Track, and you can't afford to do that)";
        }
    } else if ( LinkStatus[LinkNumber] === 8 ||
                (LinkStatus[LinkNumber] >= 0 && LinkStatus[LinkNumber] <= 4)
                ) {
        EltI.src = ImagePath + "i" + LinkStatus[LinkNumber] + ".png";
        if (LinkStatus[LinkNumber] === 8) {
            AltText += " (orphan " + LinkAltTextDescription + ")";
        } else {
            AltText += " (" +
                       LinkAltTextDescription +
                       " owned by " +
                       PersonReference(LinkStatus[LinkNumber]) +
                       ")";
        }
    } else {
        throw "Unexpected Link Status";
    }
    EltA.alt = AltText;
    EltA.title = AltText;
};

LocationName выглядит следующим образом:

var LocationName = [
    "Barrow&ndash;In&ndash;Furness", "Birkenhead",                "Blackburn", "Blackpool",
                           "Bolton",    "Burnley",                     "Bury",     "Colne",
                   "Ellesmere Port",  "Fleetwood",                "Lancaster", "Liverpool",
                     "Macclesfield", "Manchester",             "The Midlands", "Northwich",
                           "Oldham",    "Preston",                 "Rochdale",  "Scotland",
                        "Southport",  "Stockport", "Warrington &amp; Runcorn",     "Wigan",
                        "Yorkshire"
];

Ответы [ 2 ]

5 голосов
/ 05 мая 2011

Вы не устанавливаете заголовок атрибут , вы устанавливаете заголовок свойство , которое ожидает текст, а не HTML (хотя метод setAttribute также ожидает текстовую строку) .

Вообще говоря, при работе с DOM вы предоставляете текст, а не HTML. .innerHTML является заметным исключением из этого правила.

1 голос
/ 03 апреля 2013

Вот простой способ конвертировать HTML в текст:

function convertHtmlToText(value) {
    var d = document.createElement('div');
    d.innerHTML = value;
    return d.innerText;
}

Ваш код может быть обновлен до этого:

EltA.title = convertHtmlToText(AltText);
...