Удаление элемента <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
Может быть, используя строчные буквы в имени тега?