zoukankan      html  css  js  c++  java
  • Js中的onblur和onfocus事件

            html页面中,诸如按钮、文本框等可视元素都具有拥有和失去焦点的事件,这些事件在响应鼠标或键盘动作时都可激发预设的操作。本文以文本框获得和失去焦点为例简单讲解onfocus和onblur的应用。

    一. onfocus(获得焦点事件)

    当一个文本框获得焦点时,它里面的文本就像“好123”网站上的百度搜索输入框那样全部被自动选中,这样的操作可以利用onfocus来实现。

    以下的文本框,当鼠标指针移过去时,里面的文字全部被选中:

    请输入网址

    这是怎么做的呢?看以下代码及解释:

    <input type="text"name="url" value="http://www.gxblk.com" size="30"onmousemove="this.focus();this.select();">

    代码里,input标签内嵌入了onmousemove(鼠标指针经过)事件的JS语句,其等号后面的this.focus()意为其自身获得焦点;获得焦点的标志是该文本框内将出现输入光标,但要让其内的文字全部被选中,我们还得用上this.select()语句,它的意思就是选中全部文本框里的文字。

    二. onblur(失去焦点事件)

    我们经常会检测文本框是否已经被正确输入,检测工作通常在用户点击了提交按钮之后进行,事实上,利用控件失去焦点的时候,我们就可以实时进行这个检测工作,这样的话,onblur事件就派上用场了。

    以下例子有四个文本框,如果还没有任何单击它们当中的任意一个的操作,那么什么事情也不会发生,但是,当你单击了其中的任何一个使其拥有了焦点(输入光标在里面),如果什么都没有输入并且单击了别的地方令其失去焦点,就会弹出一个警告,试试看

    姓名

    性别

    年龄

    住址

    以下是代码和解释:

    表单代码

    <form name="blur_test">

       <p>姓名 <input type="text" name="name"value="" size="30"onblur="chkvalue(this)"><br>

        性别 <inputtype="text" name="sex" value=""size="30" onblur="chkvalue(this)"><br>

        年龄 <inputtype="text" name="age" value=""size="30" onblur="chkvalue(this)"><br>

        住址 <inputtype="text" name="addr" value=""size="30" onblur="chkvalue(this)"></p>

    </form>

    JS代码

    <scriptlanguage="javascript">

    function chkvalue(txt) {

       if(txt.value=="") alert("文本框里必须填写内容!");

    }

    </script>

            表单代码里,每一个方框框的代码都嵌入一个onblur JS语句,它们都调用后面的JS代码中的自定义函数chkvalue(this),意思是,当文本框失去焦点时就调用chkvalue()函数;这chkvalue()函数检测文本框是否为空,如果是就弹出警告窗口。该函数有一个参数(txt),对应于前面文本框调用该函数的参数(this)即自身。

  • 相关阅读:
    深入理解JavaScript系列(4):立即调用的函数表达式
    深入理解JavaScript系列(3):全面解析Module模式
    深入理解JavaScript系列(2):揭秘命名函数表达式
    深入理解JavaScript系列(1):编写高质量JavaScript代码的基本要点
    深入理解JavaScript系列
    大白话讲解Promise(一)
    《你不知道的JavaScript》整理(二)——this
    Mysql日期时间大全
    Mysql的时间和日期
    mysql命令大全用户管理相关命令
  • 原文地址:https://www.cnblogs.com/dyllove98/p/3159683.html
Copyright © 2011-2022 走看看