day16 DOM(2)——获取设置表单的值

目录

操作表单元素属性

  • 表单很多情况,也需要修改属性,比如点击眼睛,可以看到密码,本质是把表单类型转换成文本框
  • 正常的有属性有取值的,跟其它的标签属性没有区别
    • 获取:DOM对象.属性名
    • 设置:DOM对象.属性名=新值
javascript 复制代码
<input type="text" value="computer">
    <script>
        const uname = document.querySelector('input')
        // 获取表单属性的值用  表单.value
        // innerHTML只能获取普通元素内容,得不到表单内容
        console.log(uname.value)
        uname.value = 'sky'
        console.log(uname.value)
         </script>

注意:innerHTML只能获取普通元素内容,得不到表单内容

加上以下代码后:

javascript 复制代码
uname.type = 'password'
  • 表单属性中添加就有效果,移除就没有效果,一律使用布尔值表示。true代表添加了该属性,false代表移除了该属性。
  • 如:disabled、checked、selected
javascript 复制代码
<input type="checkbox" name="" id="">
    <script>
        const ipt = document.querySelector('input')
        console.log(ipt.checked)
    </script>

加上 ipt.checked = true

(写成ipt.checked = 'true'也可以,实际上写什么都可以,因为有隐式转换,但是不提倡)

javascript 复制代码
<input type="checkbox" name="" id="">
    <script>
        const ipt = document.querySelector('input')
        ipt.checked = true
        console.log(ipt.checked)
    </script>

disabled举例:

(注意,button是在disabled = true时禁用,默认情况下是false,不禁用)

javascript 复制代码
 <button>feiyun</button>
    <script>
        const btn = document.querySelector('button')
        console.log(btn.disabled)//默认false,不禁用按钮
        btn.disabled = true
        console.log(btn.disabled)
    </script>

H5自定义属性------data

  • 标准属性:标签自带的属性,比如class、id、title等,可以直接使用点语法操作,比如disabled、checked、sele
  • 自定义属性:
    • 在html5中推出了专门的data-自定义属性
    • 在标签上一律以data-开头
    • 在DOM对象上一律以dataset对象方式获取

举例:

javascript 复制代码
    <div data-id="1" data-spm="dontknow">1</div>
    <div data-id="2">2</div>
    <div data-id="3">3</div>
    <script>
        const one = document.querySelector('div')
        console.log(one.dataset)
        console.log(one.dataset.id)
        console.log(one.dataset.spm)
    </script>
相关推荐
Csvn1 小时前
`??` 和 `||` 搞混,线上用户头像全挂了
前端
kyriewen2 小时前
白宫前脚下了限制令,OpenAI 后脚就把 GPT-5.6 发了
前端·gpt·openai
用户40269244819083 小时前
CRMEB Pro 新增后台接口全链路:路由、权限、验证器、返回格式一次讲清
前端·后端
泉城老铁3 小时前
springboot+vue+ ffmpeg 实现视频的拉流播放
前端
PedroQue994 小时前
uni-router v1.8.0新增冷启动守卫补执行
前端·uni-app
xiaok4 小时前
部署之后,本地浏览器还在读取旧缓存导致页面一直显示loading中
前端
用户059540174464 小时前
Redis缓存一致性踩坑实录:线上故障排查6小时,我用pytest+内存快照把它永久关进了笼子
前端·css
星栈4 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:第一版先把列表和详情跑通
前端·rust·前端框架
用户1733598075374 小时前
Vue 3 SPA 首屏优化:从 3s 到 1.2s 的 5 个实践
前端·vue.js
咖啡无伴侣4 小时前
基础骨架:30 分钟搭好 pnpm workspace,完成双项目 Monorepo 迁入
前端