javascript中如何处理焦点事件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript中如何处理焦点事件相关的知识,希望对你有一定的参考价值。

焦点作为javascript中的一个重要功能,基本上和页面交互都离不开焦点。但却少有人对焦点管理系统地做总结归纳。本文就javascript中的焦点管理作详细介绍

1、焦点元素

默认情况下,只有表单元素可以获得焦点。因为只有表单元素可以交互

<input type="text" value="223">

让非表单元素获得焦点也是有办法的,先将tabIndex属性设置为-1,再调用focus()方法

<div id="test" style="height:30px;width:100px;background:lightgreen">div</div>
<button id="btn">div元素获得焦点</button>
<script>
btn.onclick = function()
    test.tabIndex = -1;
    test.focus();    

test.onfocus = function()
    this.style.background = 'pink';

</script>

2、activeElement

document.activeElement属性用于管理DOM焦点,保存着当前获得焦点的元素

注:该属性IE浏览器不支持

<div id="test" style="height:30px;width:100px;background:lightgreen">div</div>
<button id="btn">div元素获得焦点</button>
<script>
console.log(document.activeElement);//<body>
btn.onclick = function()
    console.log(document.activeElement);//<button>
    test.tabIndex = -1;
    test.focus();    
    console.log(document.activeElement);//<div>

</script>

3、获得焦点

元素获得焦点的方式有4种,包括页面加载、用户输入(按tab键)、focus()方法和autofocus属性

【1】页面加载

默认情况下,文档刚刚加载完成时,document.activeElement中保存的是body元素的引用。文档加载期间,document.activeElement的值为null

【2】用户输入(按tab键)

用户通常可以使用tab键移动焦点,使用空格键激活焦点。比如,如果焦点在一个链接上,此时按一下空格键,就会跳转到该链接

说到tab键,就不能不提到tabindex属性。tabindex属性用来指定当前HTML元素节点是否被tab键遍历,以及遍历的优先级

1、如果tabindex=-1,tab键跳过当前元素

2、如果tabindex=0,表示tab键将遍历当前元素。如果一个元素没有设置tabindex,默认值就是0

3、如果tabindex大于0,表示tab键优先遍历。值越大,就表示优先级越小

【3】focus()

focus()方法用于将浏览器的焦点设置到表单字段,即激活表单字段,使其可以响应键盘事件

注:前面介绍过,若非表单元素,设置为tabIndex为-1,也可以获取焦点

【4】autofocus

HTML5表单字段新增了autofocus属性,只要设置这个属性,不用javascript就能自动把焦点移动到相应字段 

[注意]该属性只能用于表单元素,普通元素即使设置tabIndex="-1"也不生效

【5】hasFocus()

document.hasFocus()方法返回一个布尔值,表示当前文档之中是否有元素被激活或获得焦点。通过检测文档是否获得了焦点,可以知道是不是正在与页面交互

4、失去焦点

如果使用javascript使元素失去焦点,那么就要使用blur()方法

blur()方法的作用是从元素中移走焦点。在调用blur()方法时,并不会把焦点转移到某个特定的元素上;仅仅是将焦点从调用这个方法的元素上面移走而已

5、焦点事件

焦点事件会在页面获得或失去焦点时触发。利用这些事件并与document.hasFocus()方法及 document.activeElement属性配合,可以知晓用户在页面上的行踪

【1】焦点事件共包括下面4个

blur

blur事件在元素失去焦点时触发。这个事件不会冒泡

focus

focus事件在元素获得焦点时触发。这个事件不会冒泡

focusin

focusin事件在元素获得焦点时触发。这个事件与focus事件等价,但它冒泡

focusout

focusour事件在元素失去焦点时触发。这个事件与blur事件等价,但它冒泡

[注意] 关于focusin和focusout事件,除了IE浏览器支持DOM0级事件处理程序,其他浏览器都只支持DOM2级事件处理程序

参考技术A 聚焦事件:onfocus();
失焦时间:onblur();
参考技术B 使用jquery吧
focuse事件,去jquery api文档一看就知了

在 Spring MVC 中如何处理 Ajax 请求?

【中文标题】在 Spring MVC 中如何处理 Ajax 请求?【英文标题】:How do you handle Ajax requests in Spring MVC? 【发布时间】:2012-08-02 20:48:32 【问题描述】:

在 Spring MVC(我正在使用 3.0.2)中,两个 HTTP 方法总是(或者在我看来大多是)保留(即使用适当的处理程序映射),它们是 @987654321 @如

@RequestMapping(method=RequestMethod.GET)
public String showForm(Map model)

     //Usually retrieve data from the database when the page is loaded.

     return "admin_side/Temp";

上述方法在 GET 请求时被调用。


@RequestMapping(method=RequestMethod.POST)
public String onSubmit(@ModelAttribute("tempBean") @Valid TempBean tempBean, BindingResult error, Map model, HttpServletRequest request, HttpServletResponse response)

     //Perform some basic operations with the database like insert, update or delete when the form is submitted (by clicking a submit button or so).

     return "admin_side/Temp";

上述方法是在发出 POST 请求时调用的。假设 Spring 控制器是用@RequestMapping(value="admin_side/Temp") 注解指定的。


现在,如果我需要使用 Ajax 并且需要执行与上述方法不同的功能,会发生什么?我既不能使用 GET 方法也不能使用 POST 方法处理其他方法,因为已经映射了处理程序(HTTP 方法 GET 和 POST 都保留分别处理 showForm()onSubmit() 方法)。

为了演示,我使用了method=RequestMethod.PUT的方式with Ajax 比如

@RequestMapping(method=RequestMethod.PUT)
public @ResponseBody String getStateList(@ModelAttribute("tempBean") @Valid TempBean tempBean, BindingResult error, HttpServletRequest request, HttpServletResponse response)

    return "Message";

它按预期工作,但我认为它应该是最好的解决方案。如果你有这样的场景(实际上,这对我来说似乎很常见),你如何在 Spring MVC 中处理 Ajax 请求?我应该(总是)使用RequestMethod.PUT吗? (或者 Spring 中 Ajax 的最佳 HTTP 方法是什么?)

有没有办法在同一个控制器中映射多个具有相同 HTTP 方法的方法(一个明显的答案应该是)?同样,当您需要在 Spring MVC 中使用 Ajax 时,您使用哪种方法?希望你遵循我的意思!由于我的英语还处于初级阶段,我很难表达。

【问题讨论】:

【参考方案1】:

没有AJAX 的最佳方法

至于你应该使用什么方法,这取决于建筑风格。 REST 范式及其最常见的实际解释 ROA(面向资源的架构)对 HTTP 方法的语义做出了某些假设。这是一种越来越流行的方法,我认为值得一读。不过,充分利用 REST 的优势可能需要您重新考虑整个应用程序设计。如果您决定这样做,请阅读 REST、ROA 和 JAX-RS,这是 RESTful 应用程序的 Java 标准。它的实现可以与 Spring 集成。

或者,您可以坚持使用 GET 和 POST,因为它们是支持最广泛的方法。至于 Spring 本身,这样做的合理方法是提供一个单独的 bean(或者可能是一组 bean)来处理基于 AJAX 的 API。如果您保持 URL 不同,则不会有“冲突”方法。

【讨论】:

谢谢!使用不同的 URL 完成。现在,我需要使用 Ajax(通常是 List&lt;?&gt;)从 Spring 控制器中检索数据。我现在不知道,但 Spring MVC 3.0.2 应该支持一些像 JSON 这样的机制。你知道吗?我的意思是,如果你在 Spring MVC 中使用了这些东西,你有一些链接吗?你可以拒绝我的请求,因为这不是最初的问题。谢谢。 @Tiny 这是一个使用 Jackson 库的示例:mkyong.com/spring-mvc/spring-3-mvc-and-json-example【参考方案2】:

我认为真正的问题是:

为什么您希望相同的 URL/方法组合根据访问方式而有所不同?

谁在乎您是否通过在前端发出 AJAX 请求来访问它?如果调用的语义不同,请给它一个不同的 URL。您可以直接在方法上而不是在类上指定 URL 模式,以避免重复该类的功能。

【讨论】:

谢谢!使用不同的 URL 完成。现在,我需要使用 Ajax(通常是 List&lt;?&gt;)从 Spring 控制器中检索数据。我现在不知道,但是 Spring MVC 3.0.2 应该支持一些机制,比如 JSON。你知道吗?我的意思是,如果你在 Spring MVC 中使用了这些东西,你有一些链接吗?你可以拒绝我的请求,因为这不是最初的问题。谢谢。【参考方案3】:

我们可以在单个控制器中拥有多个 GET 和 POST 方法,为此我们需要使用 value 属性

例如:

@RequestMapping(method=RequestMethod.GET, value = "/showForm")
public ModelAndView showForm()


@RequestMapping(method=RequestMethod.GET, value = "/processAjaxRequest")
public ModelAndView processAjax()

 ModelAndView modelAndView = new ModelAndView("page.jsp");  
 modelAndView.addObject("ajax_response", ajax_response);
     return modelAndView;

【讨论】:

以上是关于javascript中如何处理焦点事件的主要内容,如果未能解决你的问题,请参考以下文章

Sencha Touch V2 中如何处理方向变化

Access表单中如何处理点击功能

请问JavaScript中如何处理数字和字符串相乘的情况?

前端VUE项目中如何处理图片加载失效/裂开的问题

Jquery mobile - 如何处理body标签上的点击事件?

SpringBoot.09.SpringBoot中如何处理Filter抛出的异常