一文搞定JS事件基础与进阶
1.事件简介
2.事件的调用方式
在script标签中使用
在元素中调用
3.鼠标事件
鼠标点击
鼠标移入移除
鼠标按住松开
4.键盘事件
5.表单事件
onfocus和onblur
onselect
onchange
6.编辑事件
oncopy
onselectstart
oncontextmenu
7.页面事件
onload
onbeforeunload
8.事件监听器
9.event对象
1.事件简介
举个例子,当我们点击一个按钮时,会弹出一个对话框。其中“点击”就是一个事件,“弹出对话框”就是我们在点击这个事件里面做的一些事情。事件一般是用户对页面的一些‘小动作’引起的,如点击鼠标移动鼠标,js里边常见的事件一般有五种:
- 鼠标事件
- 键盘事件
- 表单事件
- 编辑事件
- 页面事件
2.事件的调用方式
2.1在script标签里边调用
obj.事件名 = function()
{……
};
obj是一个DOM对象
2.2在元素中调用事件
例子:
3.鼠标事件
3.1鼠标事件简介
3.2鼠标点击
例子:结合div模拟按钮
3.3鼠标移入移除
例子:
3.4鼠标的按下和松开
4.键盘事件
键盘按下:
onkeydown
键盘松开:onkeyup
例子1:统计输入字符长度(用两张事件都行只是一个是按下统计一个松开后统计)
5.表单事件
5.1onfocus和onblur
onfocus
:表示获取焦点触发的事件
onblur
:表示失去焦点触发的事件
例子1:
默认的情况需要我们点击文本框才能自动获取焦点,那么我们也可以让他们自动获取焦点,用==focus()==方法就行
例子2:自动获取焦点
5.2onselect
当我们选中单行或者多行文本框的时候,就会触发此类事件
例子:手动选中文本框触发事件
其实我们可以自动选中文本框,可以用select() 方法,看下面例子
5.3onchange
用于具有多个选项的表单元素的操作
例子1:单选框选择某一项的时候触发
例子2:复选框的全选和反选
例子3:下拉列表:
6.编辑事件
6.1oncopy
oncopy表示不能复制
例子:文字不能进行复制
6.2onselectstart
onselectstart防止页面内容被选取
例子:文字内容不可被选中
6.3oncontextmenu
oncontextmenu禁止使用鼠标右键
例子:可以选中但是不能使用鼠标右键进行复制气不气
7.页面事件
7.1onload
onload表示文档加载完成后再执行一个事件
我们看下面一段代码:
我们这一段代码点击提交的时候浏览器是会报错的,这是由于在默认的情况下,浏览器是从上到下来解析一个页面的,当解析到var oBtn = document.getElementById("btn");
的时候就会报错因为找不到id为btn的元素在哪,那么正确的使用方法是:
当浏览器解析到window.onload
时就不会解析window.onload
内部的代码而是继续往下解析,直到把整个文档解析完毕后在回去解析window.onload
内部的代码
7.2onbeforeunload
onbeforeunload表示离开页面之前触发的一个事件
我们看一个例子:
这是刚开始运行的时候。当我们关闭页面时会出现如下(具体的e是啥会在event对象里边讲):
8.事件监听器
我们直接看一个例子(下面是我第一次点击按钮出现的画面):
我们在给一个按钮添加三次onlick事件,但是js只会执行第三次,所以 事件处理器 是不能为同一元素添加多个事件的,那么这时候就需要我们的事件监听器
所谓的事件监听器指的是使用addEventListener()方法为元素添加一个事件,我们又称为绑定事件
语法:
obj.addEventListener(type,fn,false)
1.obj是一个DOM对象
2.type是一个字符串指的是事件类型如单击事件click等,注意这里的事件类型是不需要加上on作为前缀的
3.fn是一个函数名(匿名函数或者函数名)
4.false表示事件冒泡阶段调用(高级内容不详细说明)
例子1:addEventListener()方法的使用
例子2:对同一元素添加多个事件
点击按钮后会依次弹出三个对话框
例子3:多次调用window.onload
我们会发现只有我们多次使用window.onload时会发现只会执行第三个window.onload,我们也可以用
addEventListener()
方法方法来解决
那么我们既然可以使用addEventListener()方法绑定事件,那么也可以解除绑定某一个事件
语法:
obj.removeEventListener(type,fn,false)
注意这里的fn只能是函数名
例子:解除事件监听器添加的事件
当我们直接点击文字部分就会变成粉色,当我们点击解除按钮的时候,再点击文字就不会变成粉色
注意这里的
removeEventListener()
方法只能解除事件监听器添加的事件不能解除事件处理器添加的事件
当然我们也可以解除事件处理器添加的事件,如下例子:
9.event对象
当一个事件发生后,有关的这个事件的详细的信息都会临时保存在一个指定的地方,这个地方就是event对象
event常用属性:
例子1:type获取事件的类型
这个e是以什么玩意,实际上我们每次调用一个事件的时候js就会默认的给这个事件函数加上一个隐形的参数,这个参数就是event对象,一般来说event对象是作为事件函数的第一个参数,e只是一个变量名,它存储着一个event对象
例子2:keyCode获取键对应的键码
常用按键的键码:
按键 | 键码 |
---|---|
W | 87 |
S | 83 |
A | 65 |
D | 68 |
上箭头 | 38 |
下箭头 | 40 |
左箭头 | 37 |
右箭头 | 39 |
如果是shift
,Ctrl
,Alt
这几个键我们不需要使用keyCode来获取,之间通过shiftKey,ctrlKey,altKey这三个属性来获取
例子3:获取上下左右方向键
我们在点击各个方向的时候会显示相应的方向的汉字
一文搞定JS事件基础与进阶相关推荐
- 一文搞定JS中的DOM基础与进阶
文章目录: 1.DOM简介 2.获取元素 getElementByld() getElementsByTagName() getElementsByCl ...
- 【Python基础】一文搞定pandas的数据合并
作者:来源于读者投稿 出品:Python数据之道 一文搞定pandas的数据合并 在实际处理数据业务需求中,我们经常会遇到这样的需求:将多个表连接起来再进行数据的处理和分析,类似SQL中的连接查询功能 ...
- php带参数单元测试_一文搞定单元测试核心概念
基础概念 单元测试(unittesting),是指对软件中的最小可测试单元进行检查和验证,这里的最小可测试单元通常是指函数或者类.单元测试是即所谓的白盒测试,一般由开发人员负责测试,因为开发人员知道被 ...
- 一文搞定面试中的二叉树问题
一文搞定面试中的二叉树问题 版权所有,转载请注明出处,谢谢! http://blog.csdn.net/walkinginthewind/article/details/7518888 树是一种比较重 ...
- 一文搞定Matplotlib 各个示例丨建议收藏
摘要:Matplotlib 是 Python 的绘图库. 它可与 NumPy 一起使用 ,Matplotlib也是深度学习的常用绘图库,主要是将训练的成果进行图形化,因为这样更直观,更方便发现训练中的 ...
- 【语义分割】综述——一文搞定语义分割
本文记录了博主阅读的关于语义分割(Semantic Segmentation)的综述类文章的笔记,更新于2019.02.19. [语义分割]综述--一文搞定语义分割 参考文献网址 An overvie ...
- 一文搞定c++多线程同步机制
c++多线程同步机制 前序文章:一文搞定c++多线程 同步与互斥 现代操作系统都是多任务操作系统,通常同一时刻有大量可执行实体,则运行着的大量任务可能需要访问或使用同一资源,或者说这些任务之间具有依赖 ...
- 【量化交易行情不够快?】一文搞定通过Win10 wsl2 +Ubuntu+redis+pickle实现股票行情极速读写
一文搞定通过Win10 wsl2 +Ubuntu+redis+pickle实现股票行情极速读写 前言 一.准备环境分四步 1.1 给Win10装wsl2 硬件开启虚拟化 软件开启虚拟化及安装适用于Li ...
- 一文搞定Swing和Qt按钮和文本框的创建
一文搞定Swing和Qt按钮和文本框的创建 Qt的截图 java的 源码 package com.lujun;import java.awt.Container;import javax.swing. ...
最新文章
- 计算机:2014年考研大纲解析之数据结构
- 添加firefox4的deb源,直接安装
- wampserver2.5安装 redis缓存,igbinary, phalcon框架
- swift3.0 Runtime 增加属性
- Flask-SQLAlchemy插件
- 链表的头结点和尾节点的用处
- Java数据库篇7——数据库设计
- SpringMVC(十三)异常注解
- #define typedef 枚举类型
- boost::bind with ros action,ros中SimpleActionServer用boost::bind绑定多个参数
- 物质之学 —— 金属
- 【应用赏析】Las Vegas利用ParkPad(基于ArcPad)实现公园资产管理
- 常见8种无线通信协议简介
- 关于win10企业版在极域电子教室软件 v4.0 2015 豪华版的全屏控制下如何取得自由...
- 41-【JS编程接口】DOM事件与事件委托
- rar压缩文件密码破解
- xinxin -QQ登录界面
- 前端基础第五天项目 社交媒体黑马头条项目-文章模块和评论
- Java基本语法——数组
- Scala入门系列(7)-Scala之函数式编程