как удалить каждый стиль из элемента? - PullRequest
5 голосов
/ 09 января 2012

Под «удалением» я подразумеваю сброс всех стилей, которые могут опускаться на таком элементе, и установку его по умолчанию в браузере.

Мне нужно это для отладки, я не знаю, какое правило наносит вред, и яХороший подход состоит в том, чтобы удалить все стили, а затем снять ограничение по одному, чтобы проверить, когда что-то пойдет не так.

Вы видели в сети какие-либо фрагменты, которые будут состоять из:

{ right: auto !important; left: auto !important; visibility: visible !important;...

и т. Д. Через все возможные стили.

Ответы [ 4 ]

3 голосов
/ 09 января 2012

Вы не можете. Существует значение initial, предложенное в черновиках CSS3, но даже если бы оно было определено, оно установило бы свойства в исходные значения, определенные в спецификациях CSS, а не в соответствии с настройками браузера по умолчанию. Например, начальное значение свойства display равно inline, но браузеры по умолчанию не отображают все как встроенные элементы по умолчанию.

Лучшим подходом к исходной проблеме является использование средств отладки и проверки, таких как Firebug или расширение для веб-разработчиков для Firefox. Они позволяют увидеть, какие стили применяются к элементу и откуда они берутся.

1 голос
/ 09 января 2012

Если вы используете Chrome / Safari, initial отлично работает для того, что вы хотите сделать. После установки вы увидите активный стиль как initial, а вычисленный стиль - по умолчанию в браузере.

Но чтобы установить для активных стилей значение по умолчанию, создайте временный элемент и задайте для свойств элемента временные значения.

Демо: http://jsfiddle.net/ThinkingStiff/Yb9J9/

Сценарий:

Element.prototype.setDefaultStyles = function () {
    var element = document.createElement( this.tagName ),
        styles = window.getComputedStyle( element ),
        display = styles.getPropertyValue( 'display' );
    element.style.display = 'none';
    document.body.appendChild( element );

    for( style in styles ) {
        this.style[styles[style]] = styles.getPropertyValue(styles[style]);   
    };

    this.style.display = display;
    document.body.removeChild( element );
};

document.getElementById( 'unstyled' ).setDefaultStyles();

HTML:

<div id="styled">styled</div>
<div id="unstyled">unstyled</div>

CSS:

#styled, #unstyled {
    border: 1px solid red;
    color: green;
    width: 100px;
    height: 50px;
}

Выход:

enter image description here

0 голосов
/ 25 сентября 2017

попробуйте это. сделать класс с именем примерно таким, а затем использовать его

.reset-this {
    animation : none;
    animation-delay : 0;
    animation-direction : normal;
    animation-duration : 0;
    animation-fill-mode : none;
    animation-iteration-count : 1;
    animation-name : none;
    animation-play-state : running;
    animation-timing-function : ease;
    backface-visibility : visible;
    background : 0;
    background-attachment : scroll;
    background-clip : border-box;
    background-color : transparent;
    background-image : none;
    background-origin : padding-box;
    background-position : 0 0;
    background-position-x : 0;
    background-position-y : 0;
    background-repeat : repeat;
    background-size : auto auto;
    border : 0;
    border-style : none;
    border-width : medium;
    border-color : inherit;
    border-bottom : 0;
    border-bottom-color : inherit;
    border-bottom-left-radius : 0;
    border-bottom-right-radius : 0;
    border-bottom-style : none;
    border-bottom-width : medium;
    border-collapse : separate;
    border-image : none;
    border-left : 0;
    border-left-color : inherit;
    border-left-style : none;
    border-left-width : medium;
    border-radius : 0;
    border-right : 0;
    border-right-color : inherit;
    border-right-style : none;
    border-right-width : medium;
    border-spacing : 0;
    border-top : 0;
    border-top-color : inherit;
    border-top-left-radius : 0;
    border-top-right-radius : 0;
    border-top-style : none;
    border-top-width : medium;
    bottom : auto;
    box-shadow : none;
    box-sizing : content-box;
    caption-side : top;
    clear : none;
    clip : auto;
    color : inherit;
    columns : auto;
    column-count : auto;
    column-fill : balance;
    column-gap : normal;
    column-rule : medium none currentColor;
    column-rule-color : currentColor;
    column-rule-style : none;
    column-rule-width : none;
    column-span : 1;
    column-width : auto;
    content : normal;
    counter-increment : none;
    counter-reset : none;
    cursor : auto;
    direction : ltr;
    display : inline;
    empty-cells : show;
    float : none;
    font : normal;
    font-family : inherit;
    font-size : medium;
    font-style : normal;
    font-variant : normal;
    font-weight : normal;
    height : auto;
    hyphens : none;
    left : auto;
    letter-spacing : normal;
    line-height : normal;
    list-style : none;
    list-style-image : none;
    list-style-position : outside;
    list-style-type : disc;
    margin : 0;
    margin-bottom : 0;
    margin-left : 0;
    margin-right : 0;
    margin-top : 0;
    max-height : none;
    max-width : none;
    min-height : 0;
    min-width : 0;
    opacity : 1;
    orphans : 0;
    outline : 0;
    outline-color : invert;
    outline-style : none;
    outline-width : medium;
    overflow : visible;
    overflow-x : visible;
    overflow-y : visible;
    padding : 0;
    padding-bottom : 0;
    padding-left : 0;
    padding-right : 0;
    padding-top : 0;
    page-break-after : auto;
    page-break-before : auto;
    page-break-inside : auto;
    perspective : none;
    perspective-origin : 50% 50%;
    position : static;
    /* May need to alter quotes for different locales (e.g fr) */
    quotes : '\201C' '\201D' '\2018' '\2019';
    right : auto;
    tab-size : 8;
    table-layout : auto;
    text-align : inherit;
    text-align-last : auto;
    text-decoration : none;
    text-decoration-color : inherit;
    text-decoration-line : none;
    text-decoration-style : solid;
    text-indent : 0;
    text-shadow : none;
    text-transform : none;
    top : auto;
    transform : none;
    transform-style : flat;
    transition : none;
    transition-delay : 0s;
    transition-duration : 0s;
    transition-property : none;
    transition-timing-function : ease;
    unicode-bidi : normal;
    vertical-align : baseline;
    visibility : visible;
    white-space : normal;
    widows : 0;
    width : auto;
    word-spacing : normal;
    z-index : auto;
    /* basic modern patch */
    all: initial;
    all: unset;
}

Первоначально отсюда: Сброс / удаление стилей CSS только для элемента

0 голосов
/ 09 января 2012

Используйте таблицу стилей сброса, которая загружается раньше всех ваших других таблиц стилей.

Я использую модифицированную версию http://meyerweb.com/eric/tools/css/reset/

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...