jQuery基础DOM和css操作

什么是DOM?

DOM(Document Object Model) 文档对象模型,方便开发者对HTML结构元素进行修改和展示,DOM 不但内容庞大繁杂,而且我们开发的过程中需要考虑更多的兼容性、扩展性。在jQuery 中,已经将最常用的DOM 操作方法进行了有效封装,并且不需要考虑浏览器的兼容性。

  1. D 表示的是页面文档Document、O 表示对象Object,即一组含有独立特性的数据集合、M表示模型Model,即页面上的元素节点和文本节点。
  2. DOM 有三种形式,标准DOM、HTML DOM、CSS DOM,大部分都进行了一系列的封装,在jQuery 中并不需要深刻理解它。
  3. 树形结构用来表示DOM,就非常的贴切,大部分操作都是元素节点操作,还有少部分是文本节点操作。


    DOM树结构

设置元素及内容

通过我们前面所学习的选择器选中DOM之后就可以使用jQuery提供给我们的方法对DOM进行操作。
DOM操作方法:

  1. html()
    获取和设置DOM结构中的HTML内容。
    语法:
$(selector).html() // 获取DOM结构中的html内容
$(selector).html(htmlText) //设置DOM结构中的html内容
$(selector).html(function(index, value) {})  // 设置DOM结构中的HTML内容

在传入HTML文本的时候,jQuery会自动将html文本解析成标签的形式。
在使用该方法设置HTML文本的时候,会将原本的内容全部清空,如果需要对某个DOM进行内容的追加,应使用如下方法:

// 先将DOM中原本的内容获取到来,然后再追加要设置的内容
$('h2').html($('h2').html() + '要追加的内容')
  1. text()
    获取和设置DOM结构中的文本内容。
    语法:
$(selector).text() // 获取DOM中的文本内容
$(selector).text(text) // 设置DOM中的文本
$(selector).text(function(index, value) {}) // 设置DOM中的文本

html()和text()的区别在于text()方法不会解析DOM中的html标签,只会获得DOM中的纯文本,而html()方法不仅能够获取DOM中的文本,同时会解析出DOM中的标签,并且在设置的时候也可以解析传入的HTML标签。

  1. val()
    获取和设置DOM结构中的值,一般用于表单部分。
    语法
$(selector).val() // 获取表单的值
$(selector).val(value) // 设置表单的值
$(selector).val([value1, value2, ...]) // 设置多个值

在使用val()设置表单的值的时候,要注意的是,如果你要设置的是多个值,传入参数应为一个数组。

操作元素的属性

jquery除了可以对元素的内容进行操作之外,还可以对元素的属性进行操作,包括设置属性值,获取属性值以及删除属性值。

  1. attr()
    获取和设置元素的属性值
$('a').attr('href') // 获取a元素的href属性
$('a').attr('href', 'http://08643.cn') // 修改a元素的href属性值为简书
$('a').attr({'href': 'http://08643.cn', 'target': '_blank'}) // 修改a元素的href属性为简书,同时修改超链接打开方式为_blank

注意:可以使用attr()来创建ID属性和class属性,但是强烈建议不要这么去做。

  1. removeAttr()
    删除元素的属性值
$('a').removeAttr('title') // 移除a元素的title属性

该方法参数不可以为匿名函数,当该方法传入匿名函数时无效

操作元素的css样式

  1. css()
    该方法是获取和设置元素的css样式
    语法:
$('div').css('background-color') // 获取div元素的背景颜色
$('div').css(['width', 'height']) // 同时获取div元素的宽度和高度,返回一个由css属性名和属性值组成的对象
$('div').css('width', '100px') // 设置div的宽度为100px
// 如果需要设置多个css样式可用如下语法
$('div').css({
  'color': 'red',
  'background-color': 'black'
}) // 设置div的文字颜色为红色,背景颜色为黑色
// 如果需要设置多个css样式还可以使用如下语法
$('div').css('width', '100px').css('height', '100px') // 设置元素宽度和高度为100px
/**
 * 当需要设置多个css样式时,建议使用第一种方法设置
 * 当然也可以使用第一种方法,第一种方法是对css方法传入一个css属性名和属性值的键值对对象
 * 第二种方法是当第一个css样式操作完成后返回了一个jquery对象,然后再设置第二个css样式
 * 第二种方法叫做jquery的链式操作
 */
  1. addClass()
    该方法是为元素添加class
    语法:
$('div').addClass('ad') // 为div元素添加一个名为ad的class类名
$('div').addClass('wh bgcolor-red') // 为元素添加名为wh和bgcolor-red两个class
  1. removeClass()
    该方法是为元素移除class
    语法:
$('div').removeClass('wh') // 为元素div移除一个名为wh的class
$('div').removeClass('wh color-white') // 为元素div移除名为wh和color-white两个class
  1. toggleClass()
    该方法是为元素切换样式
    语法:
$('div').toggleClass('color-red') // 如果元素div存在color-red样式则移除,否则添加
$('div').toggleClass('bgcolor-black color-red') // 如果元素存在bgcolor-black和color-red样式则移除,否则添加
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容