首页 > 其他分享 >前端之DOM操作

前端之DOM操作

时间:2022-12-01 21:58:47浏览次数:35  
标签:tmp 定位 DOM 标签 前端 元素 获取 操作 document

一、概念

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

 

 


 

标签:tmp,定位,DOM,标签,前端,元素,获取,操作,document
From: https://www.cnblogs.com/brf-test/p/16936810.html

相关文章

  • 总算给女盆友讲明白了,如何使用stream流的filter()操作
    一、引言在上一篇文章中《这么简单,还不会使用java8stream流的map()方法吗?》分享了使用stream的map()方法,不知道小伙伴还有印象吗,先来回顾下要点,map()方法是把一个流中的......
  • 前端开发:2、CSS、表单标签补充说明
    前端开发之CSS目录前端开发之CSS一、表单标签补充说明二、CSS层叠样式表三、CSS选择器基本选择器CSS组合选择器分组嵌套属性选择器伪装选择器伪元素选择器四、选择器优......
  • C++输出页面的相关操作
    下文需要用到的头文件等#include<bits/stdc++.h>#include<Windows.h>#include<stdlib.h>#include<time.h>#include<conio.h>#defineintlonglongusingnamesp......
  • 前端-CSS
    1.CSS层叠样式表CSS层叠样式表主要用来调节html标签的各种样式"""思考:页面都是由HTML构成的,并且页面上有很多相同的HTML标签,但是相同的HTML标签在不同的位置可能有不......
  • Linux Bash字符串操作
    1.在SHELL中同时判断多个条件在SHELLif语句中使用"||"和"&&"要用两个独立的[]if[a-gtb]&&[a-ltc]2.判断字符串为空的方法if["$str"=""......
  • 前端开发 2
    今日内容详细表单标签的补充说明基于form表单发送数据1.用于获取用户数据的标签至少应该含有name属性 name属性相当于字典的键 用户输入的数据会被保存到标签的valu......
  • 前端(css)基础
    内容概要css选择器css层叠样式表(CascadingStyleSheets)css主要是用来调节HTML标签的各种样式/*我们现在的网页页面都是由HTML构成的,并且上面由很多相同的HTML标......
  • Web前端开发:CSS层叠样式表
    目录CSS层叠样式表-html标签的两大重要属性1.class属性2.id属性一、CSS语法结构1.语法结构2.CSS注释语法3.引入CSS的多种方式(1)嵌入式(2)外链式(3)内联样式二、CSS选择器1.CSS基......
  • 前端开发2
    今日内容概要表单标签的补充说明CSS层叠样式表CSS选择器选择器优先级CSS样式调节今日内容详细表单标签的补充说明基于form表单发送数据1.用于获取用户数据的标......
  • 前端之css
    目录前端之css今日内容概要今日内容详细表单标签补充说明CSS层叠样式表CSS选择器选择器优先级CSS样式调节前端之css今日内容概要表单标签的补充说明CSS层叠样式表......