前端小测----DOM测试38

2023-10-29 03:59

本文主要是介绍前端小测----DOM测试38,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

得分 

我得了2分,难受,明明感觉是3分的 哈哈

分析

其实这个题目就是对伪类进行了一定考察,我太菜了,呜呜呜

第一问获取所有匹配required必选的单选框元素

我的答案

var requiredInputAll = document.querySelectorAll("input[type='radio'][required]")

正解

let disabledArr = document.querySelectorAll('[type="radio"]:required');

为什么?

  • 首先input确实是不用加的因为type='radio'属性就已经可以了
  • :required伪类选择器,IE10+支持。和[required]属性选择器的区别,暂时还没找到,找到补充

第二问:获取所有匹配display禁用态的单选框元素

我的答案:其实我当时写的时候是不找到还可以有伪类这个东西的

    var disabledInputAll = []var disabledInputPart_1 = document.querySelectorAll("input[disabled]")var disabledInputAll = [...disabledInputPart_1]var disabledFieldsetInput = document.querySelectorAll("fieldset[disabled]")// console.log([].slice.call(disabledFieldsetInput)[0])Array.from(disabledFieldsetInput).forEach(item => {Array.from(item.querySelectorAll("input[type='radio']")).forEach(item => {if (!disabledInputAll.includes(item)) {disabledInputAll.push(item)}})})

正解:简单粗暴明了

let disabledArr = document.querySelectorAll('[type="radio"]:disabled');

为什么?

因为fieldset标签类的表达元素会继承fieldset的属性,所以当<fieldset>设置了disabled的时候他的子元素都会被设置

总结::disabled伪类,IE9+支持。和[disabled]属性选择器的区别,有些表单元素本身没有[disabled]属性,但是,自身是处于应用态的。这就是:disabled伪类设计的原因之一

第三问:获取所有checked选中态的单选框元素

我的答案

var checkedInputAll = document.querySelectorAll('input[checked]')

正确答案

var checkedInputAll1 = document.querySelectorAll('input:checked')

为什么?

:checked伪类,IE9+支持。和[checked]属性选择器的区别,有些单复选框虽然有[checked]属性,但是本身并不是选中态。这就是:checked伪类设计的原因之一

HTML:单选框name相同只可以选择一个,但是当我们写了2个后

<input type="radio" value="ba1" name="bookAuthor" checked>宅猪
<input type="radio" value="ba2" name="bookAuthor">西红柿
<input type="radio" value="ba3" name="bookAuthor" checked>莫默

JS

    var checkedInputAll = document.querySelectorAll('input[checked]')var checkedInputAll1 = document.querySelectorAll('input:checked')console.log(checkedInputAll.length, 'checkedInputAll--------------------') // 2console.log(checkedInputAll1.length, 'checkedInputAll--------------------') // 1

看输出结果是不一样的,所以我的分啊

第四问:获取ID为removeDisabled的按钮元素, 点击改按钮移除所有单选框元素的disabled禁用效果

我的答案:这个题目我应该是对了,但是就是谢的好像有点捞

    var removeDisabled = document.getElementById('removeDisabled')disabledInputPart_1.forEach(item => {item.removeAttribute('disabled')})disabledFieldsetInput.forEach(item => {item.removeAttribute('disabled')})

大佬的写法(我真的太菜了,其实意思是一样的)

// 这个是第二问的答案
const radiolist2 = document.querySelectorAll('[type=radio]:disabled');
// 第四问
const btn = document.querySelector('#removeDisabled');
btn.addEventListener('click',()=>{[...radiolist2].forEach(el=>{const fieldset = el.closest('fieldset:disabled');if (fieldset) {fieldset.disabled = false;}if (el.disabled) {el.disabled = false;}});
})

为什么?

Element.closest() 方法用来获取:匹配特定选择器且离当前元素最近的祖先元素(也可以是当前元素本身)。如果匹配不到,则返回 null

第五问

答案

    [type=radio]:invalid {outline: 3px dashed red;}

最优正解

    [type=radio]:invalid {outline: dashed red;}

为什么?

  • :invalid CSS 伪类 表示任意内容未通过验证的 <input> 或其他 <form> 元素
  • outline:的默认大小为3px

这篇关于前端小测----DOM测试38的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/298128

相关文章

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

HTML5 data-*自定义数据属性的示例代码

《HTML5data-*自定义数据属性的示例代码》HTML5的自定义数据属性(data-*)提供了一种标准化的方法在HTML元素上存储额外信息,可以通过JavaScript访问、修改和在CSS中使用... 目录引言基本概念使用自定义数据属性1. 在 html 中定义2. 通过 JavaScript 访问3.

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

Vue ElementUI中Upload组件批量上传的实现代码

《VueElementUI中Upload组件批量上传的实现代码》ElementUI中Upload组件批量上传通过获取upload组件的DOM、文件、上传地址和数据,封装uploadFiles方法,使... ElementUI中Upload组件如何批量上传首先就是upload组件 <el-upl

前端知识点之Javascript选择输入框confirm用法

《前端知识点之Javascript选择输入框confirm用法》:本文主要介绍JavaScript中的confirm方法的基本用法、功能特点、注意事项及常见用途,文中通过代码介绍的非常详细,对大家... 目录1. 基本用法2. 功能特点①阻塞行为:confirm 对话框会阻塞脚本的执行,直到用户作出选择。②

如何使用CSS3实现波浪式图片墙

《如何使用CSS3实现波浪式图片墙》:本文主要介绍了如何使用CSS3的transform属性和动画技巧实现波浪式图片墙,通过设置图片的垂直偏移量,并使用动画使其周期性地改变位置,可以创建出动态且具有波浪效果的图片墙,同时,还强调了响应式设计的重要性,以确保图片墙在不同设备上都能良好显示,详细内容请阅读本文,希望能对你有所帮助...