百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

DOM 操作之属性操作

myzbx 2024-12-02 22:38 52 浏览

本章目标


  • 掌握基本属性的使用
  • 掌握 textContent 和 innerHTML 的区别
  • 掌握表单属性的使用
  • 掌握自定义属性的使用

本章任务


  • 能够完成美女相册案例
  • 能够完成登录验证功能
  • 能够完成注册页面的同意协议单选框功能
  • 能够完成小图切换大图功能

属性操作


在美女画廊的案例中,我们需要获取到 img 元素,并修改 img 中显示的图片还需要获取到页面上的 p 元素修改 p 元素中显示的内容,本章中我们就来学习如何修改元素的相关属性。

基本属性


基本属性指的是 HTML 标签本身所具有的属性(HTML 中的标准属性),这些属性在浏览器把 HTML 文档生成 DOM 树的时候会自动设置为 DOM 树上元素节点对象的属性。


常用的基本属性:href、title、id、src。


获取或者设置基本属性的语法和步骤:

// 获取 DOM 元素
let dom = document.getElementById('id');
// 获取属性
console.log(dom.属性名称)
// 设置属性
dom.属性名称 = '属性值'


  • 获取元素属性的值
<a id="link" href="http://www.baidu.com">百度</a>
let link = document.getElementById('link');
// 获取元素的属性
console.log(link.id); // "link"
console.log(link.href); // "http://www.baidu.com/"
  • 设置元素属性的值
let link = document.getElementById('link');
// 设置元素的属性
link.title = 'google';
link.href = 'http://www.google.com';

你可以尝试下点击按钮修改 img 标签的图片(修改 src 属性)。

更改标签之间的内容


在美女画廊中我们需要更改 p 标签之间的内容,但是如何设置标签之间的内容?这里没有对应 HTML 的标准属性,但是这是一种常见的操作 DOM 对象提供了两个属性可以让我们方便的修改标签之间的内容:textContent 和 innerHTML,下面我们分别来介绍。


  • 获取或者设置标签之间的文本内容
let p = document.getElementById('p');
// 获取标签之间的内容
console.log(p.textContent);
// 设置标签之间的内容
p.textContent = 'Hello DOM';

你可能在其他地方见过 innerText 属性,注意这是早期 IE 中获取或者设置标签之间文本内容的属性,现代浏览器依然支持该属性,但是 DOM 中规定的标准属性是 textContent

  • 获取或者设置标签之间的 HTML 内容
let p = document.getElementById('p');
// 获取标签之间的内容
console.log(p.innerHTML)
// 设置标签之间的内容
p.innerHTML = '<b>Hello DOM</b>'
  • textContent 和 innerHTML 的区别
    • textContent 获取的内容中包含 HTML 标签会被忽略
    • textContent 设置的内容中包含 HTML 标签会直接显示
    • innerHTML 获取的内容中包含 HTML 会返回标签和内容
    • innerHTML 设置的内容中包含 HTML 标签,标签会被渲染
  • HTML 中的字符实体

在网页中有一些特殊的符号,比如:< >;想要显示这些符号需要对这些内容进行转义,也就是使用 HTML 的实体。

字符实体的表示形式:

&字符实体编号;

<   // < 显示小于号
>   // > 显示大于号

显示结果

描述

实体名称

实体编号


空格

 

<

小于号

<

<

>

大于号

>

>

&

和号

&

&

"

引号

"

"

'

撇号

' (IE不支持)

'

分(cent)

¢

¢

镑(pound)

£

£

元(yen)

¥

¥

欧元(euro)

§

小节

§

§

?

版权(copyright)

©

©

?

注册商标

®

®

?

商标

×

乘号

×

×

÷

除号

÷

÷


需要记住其中的空、>、< 的字符实体名称


案例:美女画廊


  • 需求:
    • 获取一组 a 元素
    • 获取大图对应的 img 元素
    • 获取 id 为 des 的 p 元素
    • 遍历所有的 a 元素,注册 click 事件
      • 获取 a 的 href 属性并赋值给 img 的 src 属性
      • 获取当前点击的 a 的 title 值赋值给 p 的 textContent
      • 取消 a 的默认行为(见下面注意的地方)
  • 代码:
// 1. 获取一组a元素
let links = document.getElementsByTagName('a');
// 2. 获取id为photo的img元素
let photo = document.getElementById('photo');
// 3. 获取id为des的p元素
let p = document.getElementById('des');
// 4. 循环遍历a,注册 click事件
for (let i = 0; i < links.length; i++) {
  links[i].onclick = function () {
    // 4.1 获取当前点击的a的href值赋值给 img的src属性
    photo.src =  this.href;
    // 4.2 获取当前点击的a的title值赋值给p的 textContent
    p.textContent = this.title;
    // 4.3 取消a的默认跳转行为
    return false;
  };
}


注意:给 a 元素注册点击事件的时候,如果 a 元素设置了 href 属性,当触发 a 的点击事件并且事件处理函数执行完毕后,会继续执行跳转到 href 属性,这是 a 标签的默认行为。

我们想要 a 的事件处理函数不跳转,取消 a 标签的默认行为可以在事件处理函数中 return false


表单属性


JavaScript 最初的目的是用来验证用户的输入是否合法,为了实现表单元素的验证,我们需要获取用户输入的内容,这需要使用到表单元素的属性。

  • 常用的表单元素属性
    • value:用于大部分表单元素的内容获取(option除外)
    • type:可以获取input标签的类型(输入框或复选框等)
    • disabled:禁用属性
    • checked:复选框/单选框选中属性
    • selected:下拉菜单选中属性


案例:登录的验证


  • 需求:
    • 验证用户协议是否同意
    • 验证用户名必须在 3-6 位之间,包含3和6位
    • 验证密码必须大于等于8位
  • 代码:
let btn = document.querySelector('#btn');
btn.onclick = function () {
  let username = document.querySelector('#username').value;
  let pwd = document.querySelector('#pwd').value;
  let chk = document.querySelector('#chk');

  if (!chk.checked) {
    alert('请同意用户协议');
    return false;
  }
  if (username.length < 3 || username.length > 6) {
    alert('用户名应该在3-6位之间');
    return false;
  }

  if (pwd.length < 8) {
    alert('密码必须超过8位');
    return false;
  }


  alert('我去登陆了')
  // 阻止 a 的默认行为
  return false;
};

案例:注册页面

  • 需求:
    • 同意协议的复选框选中,让完成注册按钮可用
    • 同意协议的复选框不选中,让完成注册按钮不可用
  • 代码:
// 1. 获取复选框
let agree = document.querySelector('#agree');
// 2. 获取按钮
let registerBtn = document.querySelector('#registerBtn');
// 3. 给复选框注册点击事件
agree.onclick = function () {
  registerBtn.disabled = !agree.checked;
};

案例:购物车的全选功能

  • 需求:
    • 当点击全选的 checkbox
      • 让所有商品前面的 checkbox 的选中状态和全选的 checkbox 的选中状态保持一致
    • 点击商品前面的 checkbox
      • 如果所有商品全部都选中,全选 checkbox 选中
      • 如果有一个商品没有选中,全选 checkbox 不选中
  • 代码:
// 1. 获取thead中一个复选框
let allck = document.querySelector('#all');
// 2. 获取tbody中一组复选框
//【功能1】
let cks = document.querySelectorAll('tbody input[type=checkbox]');
// 3. 给thead中一个复选框注册点击事件
allck.onclick = function () {
  // 3.1 获取thead中这个复选框的checked值
  let isOk = allck.checked;
  // 3.2 循环遍历tbody中的每一个复选框,设置checked值为thead中这个复选框的checked值
  for (let i = 0; i < cks.length; i++) {
    cks[i].checked = isOk;
  }
};

//【功能2】
// 1. 循环遍历tbody中每一个复选框注册点击事件
for (let i = 0; i < cks.length; i++) {
  cks[i].onclick = function () {
   // 2. 获取tbody中所有的复选框的个数
    let len1 = cks.length; 
    //3. 获取tbody中选中的复选框的个数
    let len2 = document.querySelectorAll('tbody input:checked').length;
    // 4. 对比是否一致,若一致,则设置thead中全选框为true,否则为false
    if (len1 === len2) {
      allck.checked = true;
    } else {
      allck.checked = false;
    }
  };
}

自定义属性


到这里为止我们介绍的都是标签所拥有的属性,也就是 HTML 中的标准属性,标签中还支持自定义属性,为了到达某些业务的需求,我们可以把数据存储到标签的自定义属性中。

例如:在购物车的案例中,如果我们要删除某个购物车中的商品的话,我们可以把这条数据的 id 存储到当前行的自定义属性中,例如:proId 这个属性。


自定义属性有两种用法,分别是:

  • 使用 DOM 中的标准 API 操作
    • getAttribute():获取标签行内属性
    • setAttribute():设置标签行内属性
    • removeAttribute():移除标签行内属性
    • 这组 API 也可以操作 HTML 的标准属性
  • HTML 5中新增的 data- 形式的自定义属性
    • 可以通过 元素.dataset 来获取或者设置 data- 后的自定义属性名称
    • 未来推荐使用这种方式存储数据,具有语义


// div
const d5 = document.querySelector('#d5');
const d6 = document.querySelector('#d6');
// 浏览器中审查元素,可以看到 d5 的 div 中会有 proId 的属性
d5.setAttribute('proId', 5)
console.log(d5.getAttribute('prodId'))

// 浏览器审查元素,可以看到 data-pro-id 的属性
// 浏览器自动把大写字母转换成了 pro-id 的形式
d6.dataset.proId = 6
console.log(d6.dataset.proId)

注意:我们获取到的自定义属性或者标准属性的值都是字符串类型。

  • 注意:元素.自定义属性 的用法
<div id="d5" prodId="5">删除</div>
<div id="d6">删除</div>

浏览器在处理 HTML 的时候,会把 HTML 文档转换为浏览器内存中的 DOM 树,在转换的过程中,标签的 HTML 标准属性会被转换为 DOM 元素的属性,但是标签的自定义属性不会转换为 DOM元素的属性。

const d5 = document.querySelector('#d5');
console.log(d5.proId);  // 打印的结果为 undefined

但是我们可以设置 DOM 元素的自定义属性,注意,这里的自定义属性并不会转换成 HTML 标签的自定义属性,仅仅是对象的属性,我们依然可以通过 DOM 对象,获取到该属性的值。

const d6 = document.querySelector('#d6');
d6.proId = 6
console.log(d6.proId);  // 打印结果为 6

案例:点击小图切换大图

<img id="small" width="80px" src="./images/small.jpg" data-big="./images/big.jpg"/>
<img id="big" src="./images/placeholder.jpg" />
let small = document.querySelector('#small');
let big = document.querySelector('#big');

small.onclick = function () {
  // 在事件处理函数中可以通过 this 获取到触发事件的元素
  // 这里的 this 就是 small 对象
  let bigImgSrc = this.dataset.big;
  big.src = bigImgSrc;
};


作业


图片切换



猜数字游戏



相关推荐

如何设计一个优秀的电子商务产品详情页

加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

怎么在JS中使用Ajax进行异步请求?

大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

前端监控 SDK 开发分享_前端监控系统 开源

一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

Ajax 会被 fetch 取代吗?Axios 怎么办?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

前端面试题《AJAX》_前端面试ajax考点汇总

1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

Ajax 详细介绍_ajax

1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

6款可替代dreamweaver的工具_替代powerdesigner的工具

dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

福斯《死侍》发布新剧照 &quot;小贱贱&quot;韦德被改造前造型曝光

时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

2025 年 Python 爬虫四大前沿技术:从异步到 AI

作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

最贱超级英雄《死侍》来了!_死侍超燃

死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

停止javascript的ajax请求,取消axios请求,取消reactfetch请求

一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...