| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> Js的三大核心之DOM -> 正文阅读 |
|
[JavaScript知识库]Js的三大核心之DOM |
? ? dom? ?获取dom元素、修改属性 ?作用:就是使用js去操作html和浏览器 dom(文档对象模型) 、bom(浏览器对象模型) ?什么是dom? dom是 document object model------文档对象模型? ? ?是用来呈现以及任意html或xml文档监护的api dom是浏览器提供的一套专门用来操作网页内容的功能 dom作用 开发网页内容特效和实现用户交互 bom树: 将html文档以树状结构直观的变现出来,我们称之为文档树或者dom树? ?dom对象:浏览器根据html标签生成的js对象 所有的标签属性都可以在这个对象(dom对象)上面找到 修改这个对象的属性会自动映射到标签身上 ?把网页内容当做对象来处理? ? ? ? ? 网页里面的标签都可以当作对象来处理 ?document对象 是dom里提供的一个对象 所以它提供的属性和方法都是用来访问和操作网页内容的 例如:document.write() 网页所有内容都在document里面 ?dom树 将html文档以树的形状直观的表现出来,我们称之为文档树或者dom树 作用:文档树直观的体现了标签与标签之间的关系 dom对象怎么创建的? 浏览器根据html标签生成的js对象(dom对象) dom的核心就是把内容当作对象来处理 document: 是dom里面的一个对象 网页所有内容都在document里面 查找dom元素就是选择页面中标签的元素 ?根据css选择器来获取dom元素(就是根据标签来获取dom元素) ?语法:document.querySelector( 'css选择器?')? ? //可以是标签、class、id之类的css选择器 参数: 包含一个或者多个有效地css选择器字符串 返回值: css选择器匹配的第一个元素,一格HTMLElement对象 如果没有匹配到,返回null ?选择匹配的多个元素 语法: document.querySelectorAll('css选择器') 参数: 包含一个或者多个有效的css选择器字符串 返回值: css选择器匹配的NodeList? 对象集合 ?获取一个dom元素我们使用:? querySelector() 获取多个dom元素使用:querySelectorAll() querySelector()方法可以直接操作修改内容 querySelectorAll方法不能直接修改内容,只能先通过遍历的方式给里面的元素做修改 ?哪怕只有一个元素,通过querySelectorAll()获取过来的也是一个伪数组,里面只有一个元素而已 ?其他获取dom元素方法 根据id获取一个元素 document.getElementById(''nav) 根据 标签获取一类元素? 获取页面 所有的div document.getElementsByTagName('div')? ? ? ? ? ? ? ? ? ? ? ? ? ?//Elements加上s的原因是所有的? +s 根据? 类名获取元素? 获取页面? 所有类名为 w 的? ? ? ? ? ?? ? ?//? ?//Elements加上s的原因是所有的? +s document.getElementsByClassName('w') ?设置/修改DOM元素内容 document.write()方法 对象.innerText属性 对象.innerHTML属性 ?只能将文本内容追加到<body>中的位置 文本中包含的标签会被解析 ?元素innerText属性 将文本内容添加/更新到任意标签位置 文本中包含的标签不会被解析 ?元素.innerHTML属性 将文本内容添加/更新到任意标签位置 文本中包含的标签会被解析 ? ?设置/修改元素常用属性 还可以通过js设置/修改标签元素属性? 比如通过src更换图片 最常见的属性:href 、title、src等 语法: 对象.属性 = 值 ?还可以通过js设置/修改标签元素的样式属性(js控制样式) 1.通过style属性操作css 2.操作类名(classname)操作css 3.通过classList操作类控制css ?设置/修改元素样式属性 通过style属性操作css 对象.style.样式属性? = 值 ?如果属性有 - 连接符,需要转换为小驼峰命名法 ?操作类名(classname)修改css 如果修改的样式比较多,直接通过style属性修改比较麻烦,我们可以通过借助css类名的形式 元素.classNmae = 'active' 由于class 是关键字,所以使用className去代替 2. className 是使用新值换旧值,如果需要添加一个类,需要保留之前的类名
?通过classList操作类控制css? 重点 为了解决className容易覆盖以前的类名,我们可以通过classList方式追加和删除类名 语法: 追加一个类 删除一个类名 元素.classList.remove('类名') 切换一个类 元素.classList.toggle('类名')
?设置/修改? 表单元素属性 ?获取: dom对象.属性名 设置:dom对象.属性名 = 新值 ?表单属性中添加就有效果,移除就没有效果,一律使用true代表添加了该属性,如果false代表移除了该属性。? 定时器--间歇函数 能够使用定时器函数重复执行代码 定时器函数可以开启和关闭定时器 ?开启定时器: setInterval(函数,间隔时间) 作用:每隔一段时间调用这个函数 间隔时间单位为毫秒 关闭定时器:? ?定时器需要关闭总不能程序一直执行下去!消耗性能,所以需要关闭 ?定时器函数可以开启和关闭定时器 关闭定时器 let? 变量名 = setInterval(函数,间隔时间) clearInterval(变量名) |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/23 9:58:03- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |