jQ常用操作dom元素的属性方法

平时都是写angular,突然想写jquery的时候发现,有时候操作元素的方法,好多都忘记了,现在抽时间把之前用过的方法都重心在熟悉一下,方便自己以后。

以下就介绍一些经常使用的jq中操作dom元素的常见方法:


.val() 和 .html() 方法
  • .val() :用于设置或返回选中元素的值
  • .html() : 用于设置或返回选中元素的HTML内容
示例:

val()方法: 用于 返回 或设置被选元素的值。

语法:

$('#id').val(value);

  • value参数是 选填 的,它 用于规定被选元素的新内容
    • 如果value 有值 的话,就是 设置 新值;
    • 如果value 没值 的话,就是 获取并返回 被选元素的当前值;
  • 多用于input元素;

html() 方法 与 val()方法的不同之处在于:html()方法返回的或设置的是被选元素的内容(类似innerHTML);

html() 的参数 可以包含标签 :

$("p").html("Hello <b>world</b>!");

html()要注意的两点:

  • 参数为空时,取值,但 只返回第一个被选元素的内容
$('p').html();
  • 参数不为空时,设置内容,但它会 覆盖所有匹配元素的内容
$(selector).html(content);
// content 可选。规定被选元素的新内容。该参数可包含 HTML 标签。

attr() 和 removeAttr()

  • attr(): 用于设置或返回匹配元素的属性和值;
  • removeAttr() : 用于移除指定的属性;

attr() 方法设置或返回被选元素的属性值

常见的几种使用情形:
  • 返回指定元素的指定属性的值:
$(选择器).attr(要获取的某个属性的属性名);
// 比如要获取id为demo的元素的高度
$('#demo').attr("height");

记得属性名也要加引号!

  • 设置属性/值
$("选择器").attr("属性名", "属性值");
// 比如设置元素的宽度
$("#id").attr("width", "600");
  • 一次设置多个属性/值
    • 使用{},以key-val的键值对形式指定属性名:属性值,多个之间以逗号隔开
$(selector).attr({attribute:value, attribute:value ...})
// 示例:
$("#id").attr({"width": "300", "height": "100" });

与之相反的是 removeAttr() 方法,它用于移除被选元素的指定属性
$(selector).removeAttr(attribute);

要注意的是,必须指定要移除哪个属性,也就是说attrbute这个属性名是必填的。

  • 示例:
$("div").removeAttr("color");

addClass() 和 removeClass()

  • addClass() : 用于 添加指定的类,这个有时候会很有用;
  • removeClass() : 与上面的方法正好相反,用于 删除 全部或某个特定的类;
  • 这两个方法其实有时候也可以 连起来一起使用,比如你先移除某个类,在追加另一个类:
<style>
.className1{ // style1 }
.className2{ //style2 }
</style>
$("p").removeClass("className1").addClass("className2");

addClass() 向被选元素添加一个或多个类

$(选择器).addClass(className);

注意:

  • 这个方法 不会移除已经存在的class属性 ,它只是在原有的基础上增加了一个或多个新的class属性,不会覆盖之前存在的class;
  • 要增加 多个class 的话, 中间以空格隔开
$("p").addClass("class1 class2");

removeClass() 方法从被选元素移除一个或多个类

$(selector).removeClass(class);

  • class ,参数选填,指定移除的类的名称;

  • 移除多个,中间加空格;

$("p").removeClass('class1 class2');
  • 如果class为空时,则移除备选元素的所有class
$("#p").removeClass();//移除id为p的元素的所有类

toggleClass() : 模拟反选,从匹配的元素中添加或删除一个类

toggleClass() : 可以对设置或移除被选元素的一个或多个类进行切换。

该方法检查每个元素中指定的类。

如果不存在则添加类,如果已设置则删除之。

这样就可以达到切换效果。

不过,通过使用 "switch" 参数,您能够规定只删除或只添加类。

$(selector).toggleClass(class,switch);

示例:
实现的效果就是,如果p标签有main这个类就移除,没有就添加。

这个很有用,记得最早之前,我做反转效果,还是用的for循环,使用的排他思想,太麻烦了;

<script type="text/javascript">
$(document).ready(function(){
  $("button").click(function(){
    $("p").toggleClass("main");
  });
});
</script>
<style type="text/css">
.main
{
font-size:120%;
color:red;
}
</style>
</head>

<body>
<h1 id="h1">This is a heading</h1>
<p class='main'>This is a paragraph.</p>
<p>This is another paragraph.</p>
<button class="btn1">切换段落的 "main" 类</button>
</body>
</html>

如何判断被选元素是否包含指定类-- hasClass()

hasClass() 方法检查被选元素是否包含指定的 class。

$(selector).hasClass(class);

  • class 必需参数,它规定需要在指定元素中查找的类。
  • 返回的结果是 布尔值
    • 如果有指定class返回true;
    • 如果不含有指定class,则返回false;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,406评论 5 475
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,976评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,302评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,366评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,372评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,457评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,872评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,521评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,717评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,523评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,590评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,299评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,859评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,883评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,127评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,760评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,290评论 2 342

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,577评论 18 139
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,845评论 6 13
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,422评论 0 4
  • 那年阔别 君亲十年长眠荒野 重逢清明时节 泪如泻 心头若刀切 思念分两列 数行追忆勾月夜 伤心难免又重写 回首重山...
    冥想抽屉阅读 293评论 0 1
  • (1)static 关键字用于修饰变量,方法,和代码块; (2)被static修饰的变量或方法不依赖于特定对象,可...
    伊凡的一天阅读 461评论 0 3