web前端第三次笔记

1事件类型

html 复制代码
获取焦点事件
ipt.addEventListener("focus", () => {
    .log("")
})

失去焦点事件
ipt.addEventListener("blur", () => {
    console.log("")
})

文本输入事件
txt.addEventListener("input", () => {
    console.log("")
})

文本改变事件
txt.addEventListener("change", () => {
    console.log("")
})

鼠标移入事件
txt.addEventListener("mouseenter", () => {
    txt.style.backgroundColor = ""
})

鼠标移出事件
txt.addEventListener("mouseleave", () => {
    txt.style.backgroundColor = ""
})

键盘按下事件
txt.addEventListener("keydown", () => {
    console.log("")
})

键盘弹开事件
txt.addEventListener("keyup", (a) => {
    console.log("")
})

页面加载事件
window.addEventListener("load", function () {
    const btn = document.querySelector("button")
    btn.addEventListener("click", () => {
        console.log("")
    })
})

滚动事件  (scrollLeft 获取元素向左滚出的高度  scrollTop 获取元素向上滚出的高度)
window.addEventListener("scroll", function () {
    console.log("")
})

尺寸事件
 window.addEventListener("resize", () => {
    console.log("")
})

捕获 冒泡事件(true 捕获;false 冒泡)
const gf = document.querySelector(".grandFather")
const f = document.querySelector(".father")
const s = document.querySelector(".son")
gf.addEventListener("click", function (e) {
    console.log("我是爷爷触发的事件")
    e.stopPropagation()
})
f.addEventListener("click", function (e) {
    console.log("我是爸爸触发的事件")
    e.stopPropagation()
})
s.addEventListener("click", function (e) {
    console.log("我是儿子触发的事件")
    e.stopPropagation()
})

2阻止表单提交

html 复制代码
const btn = document.querySelector("button")
btn.addEventListener("click", function (e) {
    e.preventDefault()
})

3事件委托

html 复制代码
const ul = document.querySelector("ul")
ul.addEventListener("click", function (e) {
    if (e.target.tagName === "LI") {
        e.target.style.backgroundColor = "red"
    }
})

4获取元素位置

html 复制代码
const box = document.querySelector("div")
const p = document.querySelector("p")
console.log(p.offsetTop)
console.log(p.offsetLeft)

5创建节点

html 复制代码
const btn = document.querySelector("button")
const ul = document.querySelector("ul")
btn.addEventListener("click", function () {
    const newLi = document.createElement("li")
})

6给新节点加入内容

html 复制代码
btn.addEventListener("click", function () {
    const newLi = document.createElement("li")
    newLi.innerHTML = ``
})

7追加节点到指定位置

html 复制代码
btn.addEventListener("click", function () {
    const newLi = document.createElement("li")
    newLi.innerHTML = ``
    ul.insertBefore(newLi, ul.children[0])
})

8克隆节点

html 复制代码
const li = document.querySelector("ul li")
const newli = li.cloneNode(true)
console.log(newli)

cloneNode(true) 表示克隆时将后代节点一起克隆,默认情况下为"false"

9删除节点

html 复制代码
const ul = document.querySelector("ul")
ul.removeChild(ul.children[1])

必须基于父元素进行删除

10setTimeout

html 复制代码
let timer2 = setTimeout('console.log("Hello Word")', 3000)
clearTimeout(timer2)

用来指定函数某段代码,在一定时间之后执行,返回一个整数,作为定时器的编号,以此后期清除定时器
根据定时器返回的整数清除定时器;在全局作用域下,this关键字指向window;对象中的this,默认指向对象本身;箭头函数没有this的作用域

11setInterval clearInterval

html 复制代码
let timer = setInterval(function (a, b) {
    console.log("hello word")
    console.log(a)
    console.log(b)
}, 1000, 1, 2)
console.log(timer)

每过一段时间运行一次代码

let timer = setInterval(function (a, b) {
    console.log("hello word")
    console.log(a)
    console.log(b)
}, 1000, 1, 2)
console.log(timer)
clearInterval(timer)

用来停止setInterval()方法执行的函数代码
相关推荐
Wect15 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
不会敲代码115 小时前
从入门到进阶:手写React自定义Hooks,让你的组件更简洁
前端·react.js
用户54330814419415 小时前
拆完 Upwork 前端我沉默了:你天天卷的那些技术,人家根本没用
前端
洋洋技术笔记15 小时前
Vue实例与数据绑定
前端·vue.js
Marshall15115 小时前
zzy-scroll-timer:一个跨框架的滚动定时器插件
前端·javascript
明月_清风17 小时前
打字机效果优化:用 requestAnimationFrame 缓冲高频文字更新
前端·javascript
明月_清风17 小时前
Markdown 预解析:别等全文完了再渲染,如何流式增量渲染代码块和公式?
前端·javascript
掘金安东尼18 小时前
用 CSS 打造完美的饼图
前端·css
掘金安东尼1 天前
纯 CSS 实现弹性文字效果
前端·css
牛奶1 天前
Vue 基础理论 & API 使用
前端·vue.js·面试