JQuery中.css()与.addClass()设置样式的区别

原创 2016年05月31日 19:35:08
对于样式的设置,我们学了addClass与css方法,那么两者之间有什么区别?

可维护性:

.addClass()的本质是通过定义个class类的样式规则,给元素添加一个或多个类。css方法是通过JavaScript大量代码进行改变元素的样式

通过.addClass()我们可以批量的给相同的元素设置统一规则,变动起来比较方便,可以统一修改删除。如果通过.css()方法就需要指定每一个元素是一一的修改,日后维护也要一一的修改,比较麻烦

灵活性:

通过.css()方式可以很容易动态的去改变一个样式的属性,不需要在去繁琐的定义个class类的规则。一般来说在不确定开始布局规则,通过动态生成的HTML代码结构中,都是通过.css()方法处理的

样式值:

.addClass()本质只是针对class的类的增加删除,不能获取到指定样式的属性的值,.css()可以获取到指定的样式值。

样式的优先级:

css的样式是有优先级的,当外部样式、内部样式和内联样式同一样式规则同时应用于同一个元素的时候,优先级如下
外部样式 < 内部样式 < 内联样式
1..addClass()方法是通过增加class名的方式,那么这个样式是在外部文件或者内部样式中先定义好的,等到需要的时候在附加到元素上
2.通过.css()方法处理的是内联样式,直接通过元素的style属性附加到元素上的
通过.css方法设置的样式属性优先级要高于.addClass方法

总结
.addClass与.css方法各有利弊,一般是静态的结构,都确定了布局的规则,可以用addClass的方法,增加统一的类规则
如果是动态的HTML结构,在不确定规则,或者经常变化的情况下,一般多考虑.css()方式。

具体看应用:

<!DOCTYPE html>
<html>

<head>
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <title></title>
    <style>
    .left,
    .right {
        width: 300px;
        height: 120px;
    }

    .left div,
    .right div {
        width: 200px;
        height: 90px;
        padding: 5px;
        margin: 5px;
        float: left;
    }
    a{
        font-size: 14px;
        display:block;
    }
    .newClass{
        background: #bbffaa;
    }

    .imoocClass{
        background: red;
    }
    .addBorder{
        border: 1px solid red;
    }

    </style>
    <script src="http://libs.baidu.com/jquery/1.9.1/jquery.js"></script>
</head>

<body>
    <h2>.addClss()与.css()方法区别</h2>
    <div class="left">
        <div class="aaron">
            <a>css优先级高于addClass</a>
            <a>1:第一次addClss背景色</a>
            <a>2:第二次css修改背景色</a>
        </div>
    </div>
    <div class="right">
        <div class="aa bb imooc">
            <article>
                <a>imoocClass</a>
            </article>
        </div>
    </div>


    <script type="text/javascript"> 
        //给所有的div统一增加边宽
        $('div').addClass("addBorder")
    </script>

    <script type="text/javascript"> 
        //class=left下div元素增加一个新的样式,增加背景颜色
        $('.aaron').addClass("newClass")
    </script>

    <script type="text/javascript"> 
        //通过css覆盖addClass方式设置背景色
        $('.aaron').css(
            {
                'background-color':'yellow'
            })
    </script>



</body>

</html>

这里写图片描述

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Jquery中.css()与.addClass()两种方法设置样式的区别

1、addClass()方法是通过增加class名的方式,类似于这个样式是在外部文件或者内部样式中先定义好的,需要时附加到元素上。 2、.css()方法定义的是内联样式,类似于直接通过元素的style...

jquery题库

1.当DOM加载完成后要执行的函数,下面哪个是正确的?( ) A jQuery(expression, [context]) B jQuery(html, [ownerDocument]) ...

jquery设置css样式、style属性 示例

css虽然会在一开始我们就定义好了,但是有很多场景需要我们动态设置css,或者单独修改一个dom控件的style属性,今天分享一下我总结的jquery设置css及style样式的方法。 一、CSS ...
  • luyaran
  • luyaran
  • 2016年11月14日 15:52
  • 12655

jQuery之addClass与removeClass使用实例

常见的用途在HTML里,多个class以空格分隔,当一个节点(或称为一个标签)含有多个class时,DOM元素响应的className属性获取的不是class名称的数组,而是一个含有空格的字符串,这就...

jquery的样式操作,类操作(添加 删除 css)

div { width: 100px; height: 100px; background-color: pink; ...

jquery addClass(添加一个css样式)

$(document).ready(function(){ $("button").click(function(){ $("p:first").addClass("intro"); ...

javascript常见的设计模式举例

近日重读《javascript面型对象编程指南》这本书,最后一章介绍了常见的javascript设计模式的实现。主要讲解了四种设计模式:单例模式、工厂模式、装饰器模式和观察者模式。js作为动态语言,实...

CSS权重的问题:选择器权重值的计算

在CSS中,会根据选择器的特殊性来决定所定义的样式规则的次序,具有更特殊选择器的规则优先于具有一般选择器的规则,如果两个规则的特殊性相同,那么后定义的规则优先。 那么,又怎么来计算选择器的特殊性...

jQuery源码分析-13 CSS操作-CSS-类样式-addClass+removeClass+toggleClass+hasClass

作者:nuysoft/高云 QQ:47214707 Email:nuysoft@gmail.com  声明:本文为原创文章,如需转载,请注明来源并保留原文链接。 jQuery源码分析系列(持续...
  • mychirs
  • mychirs
  • 2014年10月11日 16:53
  • 520

jquery怎么实现页面刷新后保留鼠标点击addclass的样式

原文: 感谢所以回答问题的人。 比较好的办法是使用url传参数,然后根据参数判断是否有必要显示class 但是更好的办法是下面这段JS $('ul.main-menu li a')....
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JQuery中.css()与.addClass()设置样式的区别
举报原因:
原因补充:

(最多只允许输入30个字)