JavaScript常用事件集合,前端小白必备(写的很详细,建议收藏)

简介: 笔记

1. 文档加载事件


  • 此事件使用频率很高,务必掌握
  • 文档加载完成之后会做的事情

1.1 ready()

  • ready(): 表示文档结构已经加载完成(不包含图片等非文字媒体文件)
// 写法一
$(document).ready(function(){
  //do something
})

1.2 onload()

  • onload(): 包含图片等文件在内的所有元素都加载完成。
  • ready() 在onload()之前加载
// 写法二
window.onload = function(){
  //do something
}


2. 鼠标事件


HTML结构如下(记得先复制这个):

<!DOCTYPE html>
<html>
    <head>
            <meta charset="utf-8" />
            <style>
                .div2,.mousemove{
                    width: 200px;
                    height: 200px;
                    background: orange;
                    color: white;
                }
                .div2{
                    background: green;
                    display: none;
                    transition: all 0.5s;
                }
            </style>
    </head>
    <body>
        <h1>鼠标事件</h1>
        <h3>mousemove: 精交互</h3>
        <div class="mousemove" onmousemove= "bodyFn(this)">
            mousemove
        </div>
        <h3>鼠标双击事件</h3>
        <button 
            id="dbBtn" 
            ondblclick="dbFn()"
            onclick="clickFn()">双击事件</button>
        <h3>鼠标悬浮事件</h3>
        <button id="btn">悬浮显示div</button>
        <div class="div2" id="div2">
            原有文字
        </div>
        <h3>键盘事件</h3>
        <input placeholder="请输入" onkeyup="keyFn(event)"/>
    </body>
</html>

2.1 鼠标悬浮事件

let btn= $my("btn");
let div2 = $my("div2");
// 鼠标悬浮事件
btn.onmouseover =  function(){
    div2.style.display = "block"; 
}
// 鼠标离开事件
btn.onmouseout =  function(){
    div2.style.display = "none"; 
}

此处的 $my() 已经进行过封装,这样很方便,代码如下:

function $my(id){
    return document.getElementById(id);
}

2.2 点击事件

 let timeId = null;     
 // 单击事件       
 function clickFn(){
      clearTimeout(timeId);
      timeId = window.setTimeout(function(){
          console.log("单击事件");
      }, 500)
  }
  // 双击事件
  function dbFn(){
      clearTimeout(timeId)
      console.log("双击事件")
  }

2.3 常用的回车事件

// 键盘事件
function keyFn(event){
    console.dir(event);
}
// 监听窗口回车事件
document.onkeyup = function(event){
   console.log(event.keyCode);
    if(event.keyCode === 13){
        alert("回车事件")
    }
}


3. 获取浏览器类型,手机机型(容易出问题的地方)


3.1 获取浏览器类型

let userAgent= navigator.userAgent;
console.log(userAgent);
if (userAgent.indexOf("Opera") > -1) {  // 判断是否是Opera浏览器
   console.log("Opera");
};
if (userAgent.indexOf("Firefox") > -1) { // 判断是否是Firefox浏览器
   console.log("Firefox");
}
if (userAgent.indexOf("Chrome") > -1) { // 判断是否是Chrome浏览器
   console.log("Chrome");
}
if (userAgent.indexOf("Safari") > -1) { // 判断是否是Safari浏览器
   console.log("Safari");
}
if (userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1) {
   console.log("IE");      // 判断是否是IE浏览器
};

3.2 判断手机机型(移动端解决兼容问题常用)

// 检测机型 安卓还是苹果
function getAdr(){
    //获取机型信息
    let type = navigator.userAgent;
    let isAndroid = type.indexOf("Android") > -1 || 
                    type.indexOf("Adr") > -1;
    return isAndroid;
}
console.log(getAdr()); // true为安卓 false为苹果


4. 事件冒泡与事件委托(面试重点)


HTML文件代码如下(记得先复制这个

<!DOCTYPE html>
<html>
 <head>
         <meta charset="utf-8" />
         <style>
             .div1{
                 width: 500px;
                 height: 100px;
                 border: 1px solid;
             }
             .p1{
                 background: orange;
             }
         </style>
 </head>
 <body>
     <h1>事件冒泡</h1>
     <div class="div1" onclick="divFn(this)">
         div的文本
         <p class="p1" onclick="pFn()">我是段落标签</p>
     </div>
     <h1>事件委托</h1>
     <ul id="ul1">
         <li>1</li>
         <li>2</li>
         <li>3</li>
         <li>4</li>
     </ul>
     <button onclick="addLi()">增加一个li</button>
 </body>
</html>

4.1 阻止事件冒泡

  • 事件冒泡:当一个元素接收到事件的时候 会把他接收到的事件传给自己的父级,一直到window
  • 显然,这是错误的,需要做处理
// 如果不做处理,点击p标签时会触发div的点击事件
function divFn(e){
     console.log("div被点击了");
}
function pFn(e){
     console.log("段落被点击了");
     window.event ? 
     window.event.cancelBubble = true : 
     // 阻止事件冒泡
     e.stopPropagation();
}

12.png 


4.2 事件委托


事件委托:把一个元素响应事件(点击事件、悬浮事件等等)的函数委托给另一个元素

举两个例子:

隔壁老王和老婆分手了,所以只能委托我去爱她老婆(好坏哦~)

放公司的快递到了,因为我请假爱老王老婆去了,所以只能委托前台签收一下

在JS中,这是一种好的处理方式:大大的减少dom操作,提升性能

不用事件委托,你得这么处理:


循环添加事件,显然,这是很蠢的

for (var i=0;i<aLi.length;i++) {
    aLi[i].onmouseover = function() {
        this.style.background = 'orange';
}
    aLi[i].onmouseout = function(){
        this.style.background = '';
    }
}

事件委托的写法

let oUl = document.getElementById('ul1');
let aLi = oUl.children;
oUl.onmouseover = function(ev){
    let ev = ev || window.event;
    let oLi = ev.srcElement || ev.target;
    if(oLi.nodeName.toLowerCase() == 'li'){
        oLi.style.background = 'orange';
    }
}
oUl.onmouseout = function(ev){
    let ev = ev || window.event;
    let oLi = ev.srcElement || ev.target;
    if(oLi.nodeName.toLowerCase() == 'li'){
        oLi.style.background = '';
    }                
}
// 后面添加的子节点也会有添加的事件
function addLi(){
   let html = document.createElement("div");
   html.innerHTML = '<li>5</li>';
   oUl.appendChild(html);
}


目录
相关文章
|
2月前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
2月前
|
JavaScript 前端开发 Java
springboot解决js前端跨域问题,javascript跨域问题解决
本文介绍了如何在Spring Boot项目中编写Filter过滤器以处理跨域问题,并通过一个示例展示了使用JavaScript进行跨域请求的方法。首先,在Spring Boot应用中添加一个实现了`Filter`接口的类,设置响应头允许所有来源的跨域请求。接着,通过一个简单的HTML页面和jQuery发送AJAX请求到指定URL,验证跨域请求是否成功。文中还提供了请求成功的响应数据样例及请求效果截图。
springboot解决js前端跨域问题,javascript跨域问题解决
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
58 5
|
2月前
|
缓存 前端开发 JavaScript
JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式
本文深入解析了JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式(Hash路由和History路由)、优点及挑战,并通过实际案例分析,帮助开发者更好地理解和应用这一关键技术,提升用户体验。
84 1
|
2月前
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
57 4
|
2月前
|
资源调度 前端开发 JavaScript
vite3+vue3 实现前端部署加密混淆 javascript-obfuscator
【11月更文挑战第10天】本文介绍了在 Vite 3 + Vue 3 项目中使用 `javascript-obfuscator` 实现前端代码加密混淆的详细步骤,包括安装依赖、创建混淆脚本、修改 `package.json` 脚本命令、构建项目并执行混淆,以及在 HTML 文件中引用混淆后的文件。通过这些步骤,可以有效提高代码的安全性。
125 2
|
2月前
|
前端开发 JavaScript 安全
vite3+vue3 实现前端部署加密混淆 javascript-obfuscator
【11月更文挑战第7天】本文介绍了在 Vite 3 + Vue 3 项目中使用 `javascript-obfuscator` 实现前端代码加密混淆的详细步骤。包括项目准备、安装 `javascript-obfuscator`、配置 Vite 构建以应用混淆,以及最终构建项目进行混淆。通过这些步骤,可以有效提升前端代码的安全性,防止被他人轻易分析和盗用。
347 0
|
3月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
223 14
|
3月前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
60 0
|
3月前
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。