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>
相关推荐
ttod_qzstudio13 分钟前
深入理解 Vue 3 的 h 函数:构建动态 UI 的利器
前端·vue.js
芳草萋萋鹦鹉洲哦18 分钟前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化
开发语言·javascript·ui
_大龄32 分钟前
前端解析excel
前端·excel
1***s63234 分钟前
Vue图像处理开发
javascript·vue.js·ecmascript
槁***耿1 小时前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶1 小时前
移动端平板打开的三种模式。
前端·javascript
前端大卫1 小时前
一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】
前端
U***49831 小时前
JavaScript在Node.js中的Strapi
开发语言·javascript·node.js
Want5951 小时前
HTML音乐圣诞树
前端·html
老前端的功夫2 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化