前端笔记-dom
dom(document object model)
-文档对象模型,包含整个页面所有功能,可以通过调用方法的形式来操作页面,所以js和dom结合在一起可以写一些逻辑性的语言
dom的对象 dom有5个对象
document 文档对象(重要),文档即页面
element object 标签对象(重要)
text object 文本对象
attrbute object 属性对象
comment object 注释对象
dom定位(在后续ui测试过程中,用selenium定位不到元素时可以用dom定位)
通过id定位(带s取所有)
document.getElementsById('123')
通过class定位(带s取所有)
document.getElementsByClassName('inner')
通过标签名定位(带s取所有)
document.getElementsByTagName('input')
通过name值定位(带s取所有)
document.getElementsByName('xxxx')
通过层级关系定位
var tmp = document.getElementById('inner1') 把查找id赋值给tmp变量
tmp.nodename 标签名
tmp.nodetype 内置标签类型号,没什么用
tmp.nodevalue 标签value值,默认为空
tmp.firstchird 第一个对象内容,可以是换行符或缩进,存在文档中的内容都可以会被返回
tmp.lastchild 最后一个对象内容
tmp.childNodes 所有对象内容
tmp.parenNode 节点(元素)的父节点,直接使用parentElement,以上方法不实用
tmp.chirdren 其变量的子元素,tmp.chirdren[0]如果有多个值取其下标
tmp.firstElementChild 取其第一个元素
tmp.lastElementChild 取其最后一个元素
tmp.parentElement 取其元素的父类元素
tmp.nextElementSibling 取其下一个相邻的标签元素(兄弟标签)
tmp.previousElementSibling 取其上一个相邻的标签元素(兄弟标签)
dom操作(在dom中你只要能获取到值就能修改)
input标签操作:
var tmp = document.getElementById('inner1').lastElementChild
tmp.value 获取到input框值是“ ” ,此时在输入值,输入tmp.value就能获取该值
tmp.lastElementChild.value='123' 在页面中也显示了该值,dom命令和页面的交互的
innerText 修改目标元素的文本内容 如果赋值的内容 <p></p>包含标签的字符串,依旧会以字符串的形式存储
innerHtml 如果赋值的内容 包含标签的字符串 他会直接转成标签元素<p></p>
select标签操作:
s1.value='xxxx' value值操作
s1.selectedIdex=2 selectedIdex下标操作,下标按数组取值
通过字符串操作css样式:
tmp="样式表中内容"
通过list方式操作css样式:
tmp.classlist 查看当前样式表下标和字符串
tmp.classlist.remove('xxx1') 删除字符串样式
tmp.classlist.add('xxx2') 增加字符串样式
直接通过style属性进行修改:
tmp.style.width='200px' 修改宽度
补充:
在html中css样式的时候写 style="background-color:red"
在dom命令中写css样式的时候写(dom不解析“-”,去"-"后面字母变成大写) tmp.style.backgroundColor='red'
dom操作原标签中的style属性
删除属性
xxx.removeAttribute('value')
添加属性
xxx.setAttribute('value','xxxxxxx') 通过字典的取值方式xxx.setAttribute[0]
创建标签
1.对象创建
document.createElement('xxx') 再通过setAttribute添加属性,只能一个一个添加
获取添加父类位置
div.appendChild(xxxx) 向当前div增加xxxx
2.字符串创建
var input = "<input type='text' value='xxx' id='xxxxx'>" 定义一个字符串
获取添加父类位置
div.insertAdjacentHTML("beforeBegin",input) 参数"beforeBegin"插入到获取标签的前面
div.insertAdjacentHTML("afterBegin",input) 参数"afterBegin"插入到获取到子标签的前面
div.insertAdjacentHTML("beforeEnd",input) 参数"beforeEnd"插入到获取到子标签的后面
div.insertAdjacentHTML("afterEnd",input) 参数"afterEnd"插入到获取标签的前面
event事件 事件也相当与一个function
onclick 单击事件var a.onclick = function (){alert("aaa");}当点击按钮后会弹出提示框 ondblclick双击
onfocis/onblur 获取焦点/失去焦点
onkeydown 某个键盘按键被按下,应用场景,登录时回车
onchange 当内容发生改变就会触发,如三级联动
onload onload事件会在游览器加载完成后才会触发,在head中加入window.load = function (){alert("aaa");}
onmouseover 当鼠标进入时触发
onmouseout 当鼠标离开时触发
onmousemove 当鼠标移动时触发
onmousedown 当鼠标被按下时触发
onselect 文本被选中
onsubmit 确认按钮被点击,与form标签绑定
方式一:
<form id='form' onsubmit='return check()'>
xxxxxx
</form>
<script>function check(event){alert('验证失败');return false;}</script>
方式二:
var a = document.getElementByid('form')'';
a.onsubmit= function(event){ event.preventDefault() } //preventDefault阻止form生成
绑定事件两种方式
1. <div id='id1' onclick='func()'></div>直接通过属性绑定
2. var obj = document.getElementsByClassName('inner')[0]
obj.onclick = function(){alert('1234')} 与html脱离,写在js中更加隐秘
事件传播
对象.stopPropagation() 阻止事件向外层div传播
版权声明:本文原创发表于 博客园,作者为 RainBol本文欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。
前端笔记-dom的更多相关文章
- 2.前端笔记之css
title: 1.前端笔记之CSS date: 2016-04-05 23:05:51 tags: 前端 categories: w3c --- 作者:刘耀 **出处:http://www.liuya ...
- 1.前端笔记之html
title: 1.前端笔记之HTML date: 2016-04-04 23:21:52 tags: Python categories: Python --- 作者:刘耀 **出处:http://w ...
- 写给后端的前端笔记:浮动(float)布局
写给后端的前端笔记:浮动(float)布局 这篇文章主要面向后端人员,对前端有深刻了解的各位不喜勿喷. 起因 前一阵子我一个后端的伙伴问我,"前端的左飘怎么做?",我立马就懵了,& ...
- 写给后端的前端笔记:定位(position)
写给后端的前端笔记:定位(position) 既然都写了一篇浮动布局,干脆把定位(position)也写了,这样后端基本上能学会css布局了. 类别 我们所说的定位position主要有三类:固定定位 ...
- 前端笔记知识点整合之JavaScript(三)关于条件判断语句、循环语句那点事
一.条件分支语句 条件分支语句,也叫作条件判断语句,就是根据某种条件执行某些语句,不执行某些语句. JS中有三种语法是可以表示条件分支的 1.1 if……else…… 条件分支的主力语法,这个主力 ...
- html学习笔记-DOM
html学习笔记-DOM Table of Contents 1. 什么是 DOM? 2. DOM 节点 3. DOM 方法 4. DOM 属性 5. DOM 访问 6. DOM 修改 7. DOM ...
- 前端笔记-html
前端笔记html 前端三大利器,html(本源),css(着装),js(动作) html 学习html就是学习一套规则能够被浏览器识别,在页面中展示,一个页面只能运行一个html 标签 <> ...
- 前端笔记之JavaScript(十)深入JavaScript节点&DOM&事件
一.DOM JavaScript语言核心.变量的定义.变量的类型.运算符.表达式.函数.if语句.for循环.算法等等.这些东西都属于语言核心,下次继续学习语言核心就是面向对象了.JavaScript ...
- 前端笔记之JavaScript(七)深入函数&DOM那点事
一.函数补充 1.1 arguments类数组对象 arguments 是一个对应于传递给函数的参数的类数组对象. 在函数中,使用特殊对象 arguments,开发者无需明确指出参数名,就能访问它们. ...
随机推荐
- dropout含义与原理
含义 在训练过程中,对神经网络单元按照一定比例暂时将其丢弃. 原理 由于网络参数过多,训练数据少,或者训练次数过多,会产生过拟合的现象.dropout产生的一个重大原因就是为了避免过拟合. 每一层的神 ...
- jqGrid全部选中
var jqGrid = $("#jqGrid"); // 拿到所有行id var jqGridIDs = jqGrid.getDataIDs(); // 拿到所有选中行id va ...
- [学习笔记] Blender 常用工具 移动与旋转,缩放, 变换
点击上面的移动图标之后,可在X,Y,Z轴移动物体. shift+S 之后,可有更多的移动选项. 旋转:可沿X,Y, Z 进行旋转 缩放 还可输入缩放的具体数值,更精确. 变换 可同时做移动.旋转.缩放 ...
- Java使用icepdf转高清图片
<dependency> <groupId>org.icepdf.os</groupId> <artifactId>icepdf-core</ar ...
- (JavaScript) 百度地图与腾讯地图坐标转换
/** * 坐标转换,百度地图坐标转换成腾讯地图坐标 * lng 腾讯经度(pointy) * lat 腾讯纬度(pointx) * 经度>纬度 */ function bMapToQQMap( ...
- [官网]Windows 10 版本信息
对应于服务选项的 Windows 10 当前版本 https://docs.microsoft.com/zh-cn/windows/release-information/ 所有的日期都按照 ISO ...
- 如何安装Oracle--新手安装Oracle教程
1. 将win32_11gR2_database_1of2.zip与win32_11gR2_database_1of2.zip 解压到当前目录 PS:选中两个压缩包后右键解压到当前文件夹:必须同时解压 ...
- java 用户线程和守护线程
在Java中通常有两种线程:用户线程和守护线程(也被称为服务线程)通过Thread.setDaemon(false)设置为用户线程通过Thread.setDaemon(true)设置为守护线程线程属性 ...
- go 函数定义
-------------------------------------------- package main import "fmt" func add(x int, y i ...
- 安装v2ra y
说明 全文中所有的‘删掉我’,都请忽略,如果不这么做,那么您将看不到这篇文章 ssr已经不行了,现在大家都以v2ra y为主 安装服务端 运行一键安装脚本,之后进入脚本界面,选“1”安装: bash ...