jquery中trigger有什么用

JavaScript022

jquery中trigger有什么用,第1张

在前端页面开发中,我们有时候希望能自定执行一些人性化操作,比如鼠标不用点击自动就能点击等操作,利用传统的js语言需要编写复杂的代码才能实现此功能,这时候我们使用jquery的trigger()方法就能轻松实现.

trigger方法的功能是在所选择的元素上触发指定类型的事件,其调用的语法格式为:trigger(type,[data]),其中参数type为触发事件的类型,参数data为可选项,表示在触发事件时,传递给函数的附件参数.下面来举例说明下.

页面中创建一个文本框,并给文本一个默认值,当该页面加载时,自动获取文本框的值,显示在页面中,同时文本框处于选中状态 .实现代码如下:

[javascript] view plain copy

$(function(){

var oTxt=$("input")//获取文本框

oTxt.trigger("select")//自动选中文本框

oTxt.bind("btn_click",function(){

//自定义事件

var txt=$(this).val()//获取自身内容

$("#div").html(txt)//显示在页面中

})

oTxt.trigger("btn_click")//自动触发自定义事件

})

trigger( event, [data] )

在每一个匹配的元素上触发某类事件。这个函数也会导致浏览器同名的默认行为的执行。比如,如果用trigger()触发一个’submit’,则同样会导致浏览器提交表单。如果要阻止这种默认行为,应返回false。

也可以触发由bind()注册的自定义事件

  $("p").click( function (event, a, b) {

// 一个普通的点击事件时,a和b是undefined类型

// 如果用下面的语句触发,那么a指向"foo",而b指向"bar"

} ).trigger("click", ["foo", "bar"])

triggerHandler( event, [data] )

这个特别的方法将会触发指定的事件类型上所有绑定的处理函数。但不会执行浏览器默认动作.

如果对一个focus事件执行了 .triggerHandler() ,浏览器默认动作将不会被触发,只会触发绑定的动作: 

<BUTTON id=old type=submit>.trigger("focus")</BUTTON>

<BUTTON id=new type=submit>.triggerHandler("focus")</BUTTON><BR><BR>

<INPUT value="To Be Focused" type=text>

<SCRIPT>

$(function(){

$("#old").click(function(){

$("input").trigger("focus")

})

$("#new").click(function(){

$("input").triggerHandler("focus")

})

$("input").focus(function(){

$("<span>Focused!</span>").appendTo("body").fadeOut(1000)

})

})

</SCRIPT>