位置: IT常识 - 正文

DOM_常用事件(dom事件种类)

编辑:rootadmin
常用事件 onload <script> window.onload = function () { ele = document.getElementById("i") console.log(ele.innerHTML); } </script> </head> <body> <div clas ... 常用事件onload<script> window.onload = function () { ele = document.getElementById("i") console.log(ele.innerHTML); } </script></head><body><div class="background"> <div id="i">ivanlee</div></div>

推荐整理分享DOM_常用事件(dom事件种类),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:dom事件有哪些阶段,dom事件模型由什么组成,常见的dom事件,dom事件种类,dom事件有哪些阶段,dom常用事件,dom事件种类,dom常用事件,内容如对您有帮助,希望把文章链接给更多的朋友!

window.onload的方法解决了js在从上到下编译的时候,无法先解析body里面的内容,后解析<script>标签里的事件。

现在script标签在上面,div标签在下面,加入onload方法可以在解析时进行等待,等到解析完div标签。

onsubmit

很多检验是在提交服务器之前进行的,运用onsubmit方法可以在本地进行验证,如果出错了可以立即停止,不需要交给服务器

<form action="" id="i"> 用户名 <input type="text"> 密码 <input type="password"> <input type="submit"></form></div><script> var ele = document.getElementById("i"); var user = document.querySelector("#i [type=text]") var pwd = document.querySelector("#i [type=password]") ele.onsubmit = function (e){ if(user.value.length < 5){ alert(user.value+"长度应该大于5") return false; // 终止事件执行 // e.preventDefault() // 阻止元素默认行为 } }</script>

当用户名长度小于5时,点击提交之后就会弹窗提示(这个过程不会传给服务器)

onchange <select name="provonce" id="s1"> <option value="hebei">请选择省份</option> <option value="hubei">湖北省</option> <option value="hunan">湖南省</option> <option value="hebei">河北省</option> </select> <select name="provonce" id="s2"> <option value="hebei">请选择城市</option> </select></div><script> var data={"hunan":["长沙","岳阳","张家界"],"hubei":["武汉","襄阳","荆州"],"hebei":["石家庄","保定","张家口"]}; var ele = document.getElementById("s1"); var ele2 = document.getElementById("s2"); ele.onchange = function (){ var cities = data[this.value]; //Array ele2.options.length = 1; //1代表有一个默认显示值:请选择城市 for (var i=0;i<cities.length;i++){ var opt = document.createElement("option"); opt.innerText = cities[i]; ele2.appendChild(opt); } }</script>

onmouse<div id="container"> <div id="title">使用了onmouse事件↓</div> <div id="list"> <div class="item1">第一行</div> <div class="item2">第二行</div> <div class="item3">第三行</div> </div> </div><script> // 1.不论鼠标指针离开被选元素还是任何子元素,都会触发 mouseout 事件。 // 2.只有在鼠标指针离开被选元素时,才会触发 mouseleave 事件。 var container=document.getElementById("container"); var title=document.getElementById("title"); var list=document.getElementById("list"); title.onmouseover = function(){ list.style.display="block"; } container.onmouseleave = function(){ list.style.display="none"; }</script>

onmouseout表示鼠标悬停事件已经发生之后的动作

如果没有离开的动作,那么这三行将会一直被显示,那就需要onmouseleave,表示鼠标离开区域之后发生的动作

DOM_常用事件(dom事件种类)

移开鼠标之后又恢复原来的样子

onkey<input type="text" id="i1"/><script type="text/javascript"> var ele=document.getElementById("i1"); ele.onkeydown=function(e){ console.log("onkeydown",e.key) }; ele.onkeyup=function(e){ console.log("onkeyup",e.keycode) };

onkeyup 事件会在键盘按键被松开时发生。

onkeydown 事件会在用户按下一个键盘按键时发生。

与onkeyup 事件相关的事件发生次序:

onkeydownonkeypressonkeyup

onblur and onfocusvar ele = document.querySelector("#i1");// 获取焦点事件ele.onfocus = function () { console.log("in")};// 失去焦点事件 ele.onblur = function () { if(ele.value.length<5){ ele.value = "太短了,重新输入"; }}

当鼠标点击框的时候,是获取焦点事件鼠标移开以后就失去了,用法就是可以实时的进行判断,如果输入结束可以立即判断输入是否合法。

点击输入框,就输出in了,当我输入‘12’以后并且点击其他地方

冒泡区域

现有两块区域,小的c2,大的c1

<div class="c1"> <div class="c2"></div> </div> <script> var ele1 = document.querySelector(".c1"); ele1.onclick = function () { alert("c1区域") }; var ele2 = document.querySelector(".c2"); ele2.onclick = function (event) { alert("c2区域"); // 如何阻止事件冒泡 event.stopPropagation(); } </script>

一般情况下,鼠标进入绿色区域后,会弹窗显示“c1区域”,到达蓝色部分后会依次弹窗显示“c2区域”,“c1区域”

如果想要达到蓝色区域只属于c2区域,不向外延伸,就加入一个stopPropagation

本文链接地址:https://www.jiuchutong.com/zhishi/310140.html 转载请保留说明!

上一篇:php中__callStatic方法的使用(php static function)

下一篇:discuz 发帖默认权限 模板修改方法(discuz发帖标签)

  • 盘亏存货进项税额转出的计算公式
  • 娱乐行业缴纳的税收
  • 双定户经营所得用申报吗
  • 生产用天然气如何入账
  • 财政部监制章可以报销吗
  • 工程咨询属于什么合同
  • 做实验用的东西哪里可以买到
  • 制造业三项费用占比行业怎么算
  • 母公司给子公司担保的规定
  • 上年度没有计提企业所得税
  • 销售废旧物资增值税新政策
  • 报废资产取得的增值税
  • 购入债券计入什么科目
  • 公司多久不做账会被注销?
  • 国外预提税是什么
  • 营改增后小规模纳税人
  • 增值税税负率计算包含附加税吗
  • 汽车修理厂可以安装车牌吗
  • 小额贷款公司可以跨区域经营吗
  • 营改增的项目
  • 货物出口被海关查
  • 销售净利率计算公式是什么
  • 开户许可证复印件是什么
  • 建筑设计公司的账务处理
  • 合伙制创投企业与合伙制创投基金
  • 小型微利企业普惠性企业所得税减免政策解读
  • u盘做的启动盘在哪里
  • windows7便签删除了怎么恢复
  • springboot集成camunda+bpmn
  • remupd.exe - remupd是什么进程 有什么用
  • php __destruct
  • scvc8.exe是什么
  • mpd linux
  • 房地产企业收入确认
  • php rsa
  • 一般纳税人简易计税会计分录
  • 开源模型:小羊驼(Vicuna-13B),可达chatGPT九成效果。
  • 物业代收代缴费 没住户怎么办
  • 未记账凭证怎么变成已记账凭证
  • 利润表中的管理费用怎么填
  • 教育经费什么情况下可以报销
  • mysql复制表结构及数据
  • 赠品视同销售价格如何确定
  • 小微企业季度申报所得税税率
  • 现金流量表直接法的优缺点
  • 集团内部借款利率如何确定
  • 以前年度损益调整怎么做账
  • 起征点和免征额都是税收优惠形式
  • 一般纳税人转小规模纳税人的条件
  • 已确认收入但尚未发出商品分录
  • 收到采购材料发票款未付会计分录
  • 土地出让金返还比例是多少
  • 出纳去银行取钱需要带什么
  • 处理报废的固定资产账务处理
  • 退税勾选选成抵扣勾选怎么办
  • 销售收入用营业收入还是营业总收入
  • 某酒店住宿费用定价分析
  • 金蝶当月没有账如何结转到下月
  • sql语句错误提示
  • ubuntu14.4安装教程
  • win10不是自己的账户
  • .exe是什么软件
  • linux扩容inode
  • win8正版系统自带
  • bootstrap导航都有哪些
  • 十大经典排序算法总结
  • 跨域请求的三种方法
  • shell自动化
  • 查看系统网络连接数
  • 什么叫屏蔽屏幕按键
  • jquery设置宽高
  • shell脚本相互调用
  • JavaScript中Number.NEGATIVE_INFINITY值的使用详解
  • python 内置函数什么用来返回序列中的最大元素
  • python如何运用
  • 江苏税务怎么登陆
  • 南宁市税局官网
  • 浙江省国家电子税务局官网登录
  • 2021年河南省企业退休职工丧葬抚恤金标准
  • 广东省电子税务局app
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设