黑马前端-Web APIs—设置/修改DOM元素内容和元素属性

教程:JavaScript核心之Web APIs实用案例
前期更新笔记内容:Web API 基本认知 /  获取DOM元素

一、设置/修改DOM元素内容

目标:能够修改元素的文本更换内容
 
DOM对象都是根据标签生成的,所以操作标签,本质上就是操作DOM对象。 就是操作对象使用的点语法。
 
如果想要修改标签元素的里面的 内容 ,则可以使用如下几种方式:
 
学习路径:
1. document.write() 方法
2. 对象.innerText 属性
3. 对象.innerHTML 属性

1. document.write()

  •  只能将文本内容追加到 </body> 前面的位置
  •  文本中包含的标签会被解析

例子:

2. 元素innerText 属性

  •  将文本内容添加/更新到任意标签位置
  •  文本中包含的标签不会被解析

例子:

 

3. 元素.innerHTML 属性

  •  将文本内容添加/更新到任意标签位置
  •  文本中包含的标签会被解析

例子:

知识小结:

1. 设置/修改DOM元素内容有哪3钟方式?
  •  document.write() 方法
  •  元素.innerText 属性
  •  元素.innerHTML 属性
2. 三者的区别是什么?
  •  document.write() 方法 只能追加到body中
  •  元素.innerText 属性 只识别内容,不能解析标签
  •  元素.innerHTML 属性
  •  能够解析标签
  •  如果还在纠结到底用谁,你可以选择innerHTML

案例:随机抽取的名字显示到指定的标签内部

需求:将名字放入span 盒子内部
 
分析:
 
①:获取span 元素
②:得到随机的名字
③:通过innerText 或者 innerHTML 讲名字写入元素内部

二、设置/修改DOM元素属性

1. 设置/修改元素常用属性

  •  还可以通过 JS 设置/修改标签元素属性,比如通过 src更换 图片
  •  最常见的属性比如: href、title、src 等
  •  语法:

例子:

 

 案例:页面刷新,图片随机更换

需求:当我们刷新页面,页面中的图片随机显示不同的图片

 

分析:
 
①:随机显示,则需要用到随机函数
 
②:更换图片需要用到图片的 src 属性,进行修改
 
③:核心思路:
 
1. 获取图片元素
 
2. 随机得到图片序号
 
3. 图片.src = 图片随机路径
 

2. 设置/修改元素样式属性

还可以通过 JS 设置/修改标签元素的样式属性。
 
  •  比如通过 轮播图小圆点自动更换颜色样式
  •  点击按钮可以滚动图片,这是移动的图片的位置 left 等等
学习路径:
 
1. 通过 style 属性操作CSS
 
2. 操作类名(className) 操作CSS
 
3. 通过 classList 操作类控制CSS
 

2.1通过 style 属性操作CSS

语法:


小结 : 

1. 设置/修改元素样式属性通过(style)属性引出来?
2. 如果需要修改一个div盒子的样式,比如 padding-left, 如何写?
  •  element.style.paddingLeft = ‘300px’
  •  小驼峰命名法
3. 因为我们是样式属性,一定别忘记,大部分数字后面都需要加单位

案例: 页面刷新,页面随机更换背景图片

需求:当我们刷新页面,页面中的背景图片随机显示不同的图片

分析:
 
①: 随机函数
②: css页面背景图片 background-image
③: 标签选择body, 因为body是唯一的标签,可以直接写 document.body.style

2.2 操作类名(className) 操作CSS

如果修改的样式比较多,直接通过style属性修改比较繁琐,我们可以通过借助于css类名的形式。
语法:

 

注意:
 
1. 由于class是关键字, 所以使用className去代替
 
2. className是使用新值 旧值, 如果需要添加一个类,需要保留之前的类名
 
小结
 
1. 使用 className 有什么好处?
 
☞  可以同时修改多个样式
 
2. 使用 className 有什么注意事项?
 
☞  直接使用 className 赋值会覆盖以前的类名

2.3 通过 classList 操作类控制CSS

为了解决className 容易覆盖以前的类名,我们可以通过classList方式追加和删除类名

语法:

 

小结
 
1. 使用 className 和classList的区别?
  •  修改大量样式的更方便
  •  修改不多样式的时候方便
  •  classList 是追加和删除不影响以前类名

3. 设置/修改 表单元素 属性

表单很多情况,也需要修改属性,比如点击眼睛,可以看到密码,本质是把表单类型转换为文本框
正常的有属性有取值的 跟其他的标签属性没有任何区别
  •  获取: DOM对象.属性名
  •  设置: DOM对象.属性名 = 新值

 

表单属性中添加就有效果,移除就没有效果,一律使用布尔值表示 如果为true 代表添加了该属性 如果是false 代表移除了该属性
 
比如: disabled、checked、selected


 

 
下篇预告:Web APIs  定时器-间歇函数


黑马前端专栏干货多多,关注再学,好方便~

2022年前端学习路线图:课程、源码、笔记,技术栈  另外此线路图实时更新!需要课后资料的友友们,可以直接告诉我。

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值