默认行为及阻止

默认行为及阻止

浏览器以及HTML元素提供了一些默认行为,也可以称作默认事件。

默认行为

a标签点击跳转

<a>标签在href存在的情况下会点击自动跳转链接或者定位锚点,通过对<a>的监听事件阻止默认行为后,点击链接不会跳转。

html 复制代码
<a href="https://blog.touchczy.top" id="t1">点击跳转链接</a>
<script type="text/javascript">
    document.getElementById("t1").addEventListener("click", (e) => {
        e.preventDefault();
    })
</script>

鼠标右击显示菜单

在浏览器页面中鼠标右击会显示菜单,通过对document的监听事件阻止默认行为后,右击页面不会弹出菜单,当然也可以通过监听并组织默认行为制作自定义右键菜单。

html 复制代码
<script type="text/javascript">
    document.addEventListener("contextmenu", (e) => {
        e.preventDefault();
    })
</script>

input输入

<input>或者<textarea>获得焦点时敲击键盘会自动输入,阻止默认行为后,敲击键盘将不会输入,可以在这个事件监听下作输入数据过滤,例如只允许输入数字。

html 复制代码
<input id="t3" />
<script type="text/javascript">
    document.getElementById("t3").addEventListener("keydown", (e) => {
        e.preventDefault();
    })
</script>

复选框选中

复选框的默认行为下是点击选中获取取消选中,阻止默认行为后,点击将不会改变目前状态。

html 复制代码
<input id="t4" type="checkbox" />
<script type="text/javascript">
    document.getElementById("t4").addEventListener("click", (e) => {
        e.preventDefault();
    })
</script>

表单提交

表单中若是存在typesubmit<input>或者是<buttton>都会触发表单的提交,阻止默认行为后表单不会自动提交。

html 复制代码
<form action="./" id="t5">
    <input type="submit" name="btn" />
</form>
<script type="text/javascript">
    document.getElementById("t5").addEventListener("submit", (e) => {
        e.preventDefault();
    })
</script>

阻止默认行为

  • W3C推荐的阻止默认行为的方式是event.preventDefault(),此方法只会阻止默认行为而不会阻止事件的传播。
  • IE8及之前的浏览器阻止默认行为需要使用window.event.returnValue = false
  • 直接在事件处理函数中return false也能阻止默认行为,只在DOM0级模型中有效。此外,在jQuery中使用return false会同时阻止默认行为与事件传播。

示例代码

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <title>默认行为及阻止</title>
</head>
<body>
    <a href="https://blog.touchczy.top" id="t1">点击跳转链接</a>
    <input id="t3" />
    <input id="t4" type="checkbox" />

    <form action="/" id="t5">
        <input type="submit" name="btn" />
    </form>

    <a href="https://blog.touchczy.top" id="t6">点击跳转链接</a>

</body>
<script type="text/javascript">
    document.getElementById("t1").addEventListener("click", (e) => {
        e.preventDefault();
    })

    document.addEventListener("contextmenu", (e) => {
        e.preventDefault();
    })

    document.getElementById("t3").addEventListener("keydown", (e) => {
        e.preventDefault();
    })

    document.getElementById("t4").addEventListener("click", (e) => {
        e.preventDefault();
    })

    document.getElementById("t5").addEventListener("click", (e) => {
        e.preventDefault();
    })

    document.getElementById("t6").onclick = (e) => {
        return false;
    }
</script>
</html>

每日一题

arduino 复制代码
https://github.com/WindrunnerMax/EveryDay

参考

bash 复制代码
https://segmentfault.com/a/1190000007681900
http://www.imooc.com/article/259535?block_id=tuijian_wz
https://developer.mozilla.org/zh-CN/docs/Web/API/Event/preventDefault
相关推荐
wordbaby10 分钟前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩12 分钟前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思1 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫3 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。4 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星4 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒4 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩4 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi4 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
哆来A梦没有口袋5 小时前
干货精讲 | 初级CSS面试高频考题
前端·css·面试