每天努力一点点,坚持下去 ------ 博客首页

前端之DOM操作

一、概念

javascript

  • javascript是一种脚本语言,可以被浏览器解析,所以它可以称之为前端的三把利器之一。
  • javascript跟java没有半毛钱关系。
  • 声明局部变量:使用关键字var
  • 应用场景:当Selenium定位不到元素时,就要使用js代码来定位了

Dom

  • Document object model文档对象模型
  • 它就是把死板的标签变成可以通过方法调用的对象,对象里面囊括了页面里的所有元素、功能
  • 通过Dom提供的调用方式,来操纵这个页面当中的元素。类似于对象,它可以调用里面任何的东西
  • dom想操作页面,是因为有一套定位功能

Js+Dom

  • 是有逻辑性的操作页面
  • js是脚本语言,可以写逻辑性代码
  • dom是文档对象模型,可以直接操作页面
  • js与dom的关系,就类似于python之与对象

js局部变量的使用:

二、DOM的具体功能

(一)定位元素

1、直接定位

(1)通过id进行定位

document.getElementById('account')

缺点:如果这个元素没有id就无法定位到了

 (2)通过class属性定位

document.getElementsByClassName('el-input__inner')

使用.getElementsByClassName(),可以获取列表

优点:如果没有id属性,可以使用class属性定位到。

缺点:费事,如果有直接能定位到的方法,绝对不要用加s的这种方式

(3)通过标签进行定位

document.getElementsByTagName('input')

使用.getElementsByTagName(),可以获取列表

优点:如果没有id属性,可以使用标签属性定位到。

缺点:费事,如果有直接能定位到的方法,绝对不要用加s的这种方式

 (4)通过标签的name属性进行定位

document.getElementsByName('username')

使用.getElementsByClassName(),可以获取列表

优点:如果没有id属性,可以使用标签属性定位到。

缺点:费事,如果有直接能定位到的方法,绝对不要用加s的这种方式

 

 

2、从能定位到的相邻的元素来定位

(1)获取子标签元素

  • 通过.children[]方法来定位子标签元素

(2)获取第一个子标签元素、最后一个子标签元素

  • 通过.firstElementChild方法来定位第一个子标签元素
  • 通过.lastElementChild方法来定位最后一个子标签元素
var tmp=document.getElementById('inner1')
tmp
tmp.firstElementChild
tmp.lastElementChild

(3)获取父元素

  • 通过.parentElement方法获取父节点标签元素
var tmp=document.getElementById('app') 
tmp.parentElement

(4)获取下一个兄弟标签元素

  • 通过.nextElementSibling方法获取下一个兄弟标签元素
var tmp=document.getElementById('app')
tmp.nextElementSibling

(5)获取上一个兄弟标签元素

  • 通过.previousElementSibling方法获取上一个兄弟标签元素
var tmp=document.getElementById('account')
tmp.previousElementSibling

(二)操纵元素

  • 在dom中,只要能操纵的元素,就能修改

1、操纵行内标签、块级标签

(1)获取元素值

  • 通过.value方法来获取元素值
var tmp=document.getElementById('account')
tmp.value

(2)修改元素值

  • 通过给获取到的元素赋值来修改
var tmp=document.getElementById('account')
tmp.value
tmp.value='hahahah'

(3)获取到标签内容再修改

(a).innerText方法获取标签名

  • 通过.innerText方法只能获取到标签名

通过赋值进行修改

  • innerText用来修改标签内的文本内容,也就是说,它只修改标签与标签之间夹着的内容,必须是闭合标签

(b)获取标签中所有内容

  • 通过.innerHTML方法获取到标签中的所有内容

(c)区别与联系

  • innerText修改目标元素的文本内容,如果赋值的内容是<p></p>这种包含标签的字符串,则修改后依旧会以字符串的形式存储

  •  innerHTML如果赋值的内容包含是包含标签的字符串,会直接转成标签

2、操纵select标签

(1)获取元素值

(a)通过.value方法

 select:value属性获取select的选项,或者修改选项

  •  select标签赋值元素值,可以根据页面上元素内容的变化而变化

  • 必须要赋值选项中存在的值,不存在的赋值完了也是空:

(b)通过.selectedIndex方法

  • 输入已有元素的下标值,可以定位到元素:

 

 selectedIndex:获取选项的下标,通过下标也可以对select的选项进行修改

3、操纵样式

(1).className方法

  • 通过.className方法,可以定位到同时有两个样式的元素:

var tmp=document.getElementById('clst')
tmp

(2).classList方法

  • 通过.classList方法,可以获取到样式列表(这个列表不是真的列表,但可以用列表方式进行操作)
var tmp=document.getElementById('clst')
tmp.classList

缺点:只能操作已经存在样式的元素

(a)删除样式

  • 使用.classList.remove('样式名')方法
var tmp=document.getElementById('clst')
tmp.classList.remove('tmp1')
tmp.classList

 

(b)添加样式

  • 使用.classList.add('样式名')方法
var tmp=document.getElementById('clst')
tmp.classList.remove('tmp1')
tmp.classList.add('tmp2')

(3).style方法

  • 优点:可以直接添加原来没有的样式

在工作中,经常会遇到display属性=none的情况,开发会在上面再盖一层好看的样式,这样我们会定位不到,此时就要使用这个方法了,将最下面那层定位到

.style方法操作的是标签中的属性

(a)直接添加没有的样式:

添加前:

 

 由于tmp.style是操作的标签中的属性,而标签此时没有width这个属性,所以定位不到:

 添加后:

 

 实际上是将属性添加到标签上了:

(b)定位到被隐藏的元素:

隐藏元素:

var tmp=document.getElementById('clst')
tmp.style.display='none'

 还原被隐藏的元素:

var tmp=document.getElementById('clst')
tmp.style.display=''

(c)css与js的一点区别

  • 在css中,style=background-color属性是-color,而js无法解析【 - 】,所以会将css中有【 - 】的属性都变成【 - 】后面的第一个字母大写,变成backgroundColor。
  • 如果在js中仍然按照css中的写法去写,会报错:

 正确写法:

var tmp=document.getElementById('clst')
tmp.style.backgroundColor='green'

 

创建标签

(1)对象方式创建标签

createElement(tagName) //通过DOM创建一个标签对象
 
appendChild(tagObj) //在父级标签内添加一个子标签对象

 

(2)字符串方式创建标签

insertAdjacentHTML(where, tagStr) //父级标签内或外添加一个子、兄标签
 
beforeBegin //插入到获取到标签的前面
 
afterBegin //插入到获取到标签的子标签的前面
 
beforeEnd //插入到获取到标签的子标签的后面
 
afterEnd //插入到获取到标签的后面

 

 Tip:

简便方法,直接看提示:从下图红框中的提示中可以看出:

  • select为标签名,#代表这个标签有名为s1的id属性,如果有.代表这个标签有名为xxx的class属性,定位的时候就不用特意去点进去看了

 


 

posted @ 2022-12-01 21:42  他还在坚持嘛  阅读(240)  评论(0编辑  收藏  举报