Удаление элемента <link> с помощью jQuery?

Я не хочу использовать стили из style.css, поэтому решил удалить style.css из DOM. Эта работа прекрасно работает в Firefox и IE8, но не в IE6:

$("LINK[href='http://www.example.com/style.css']").remove();

Любое другое решение с jQuery?


Вот пример:
HTML:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Testing</title>
<script type="text/javascript" src="path/to/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function() {
    $("link[href*='style.css']").remove();         
});
</script>
<link rel="stylesheet" type="text/css" href="style.css" />
</head>
<body>
<div id="content">...</div>
</body>
</html>

И вот CSS (style.css):

#content {
    background-color:#333;
}

Только в IE #content все еще темно.:(
Может быть, ошибка jQuery?

Ответ 1

Это не ошибка в jQuery, это ошибка (или, возможно, функция) механизма рендеринга IE.

Кажется, эта проблема вызвана тем фактом, что Internet Explorer неправильно отображает страницу после удаления элемента LINK из DOM.

В этом конкретном случае тег LINK больше не присутствует в DOM, но IE по-прежнему отображает CSS, который был загружен в память.

Обходной путь/решение для этого - отключить таблицу стилей с помощью свойства .disabled следующим образом:

// following code will disable the first stylesheet
// the actual DOM-reference to the element will not be removed; 
// this is particularly useful since this allows you to enable it
// again at a later stage if you'd want to.
document.styleSheets[0].disabled = true;

EDIT в ответ на ваш комментарий:

Или, если вы хотите удалить его с помощью href, используйте следующий код:

var styleSheets = document.styleSheets;
var href = 'http://yoursite.com/foo/bar/baz.css';
for (var i = 0; i < styleSheets.length; i++) {
    if (styleSheets[i].href == href) {
        styleSheets[i].disabled = true;
        break;
    }
}

Ответ 2

Возможно, что-то странное IE6 делает для URL-адреса в атрибуте href? Попробуйте что-то вроде:

$("LINK[href*='style.css']").remove();

(т.е. проверьте, содержит ли значение href "style.css" )

Это просто предположение. Если это не сработает, я рекомендую внимательно проверить документацию JQuery на тему селекторов атрибутов и метода remove.

Также имейте в виду, что это также не невозможно, что это на самом деле ошибка. (IE6 вообще вызывает множество проблем, связанных с манипулированием JavaScript и DOM, между прочим.)

Ответ 3

Тема довольно старая, но вы можете добавлять только идентификатор в свой элемент ссылки и удалять его по элементу:

$("#id").remove();

Ответ 4

Может быть, используя строчные буквы в имени тега?