JQuery实战中遇到的两个小问题$(document).ready() 、bind函数的参数传递问题
2013-08-22 19:30
393 查看
一、$(document).ready() 与 window.onload的区别
1.执行时间
window.onload 必须等到页面内所有元素(包括图片 css js等)加载完毕后才会执行。
$(document).ready() 是DOM结构绘制完毕后就执行,不必等到所有元素加载完。
2.编写个数不同
window.onload不能同时编写多个,如果有多个window.onload方法,只会执行一个。
$(document).ready()可以同时编写多个,并且都可以得到执行,根据写的顺序决定先执行哪个。
3.简化写法
window.onload没有简化写法 $(document).ready(function() {})可以简写成$(function(){});
二、bind函数的参数传递问题
bind函数的定义: $(selector).bind(event,[data,]function)
很多刚开始用jquery的同学在用bind时都会犯过此类错误 $(“#id”).bind( “click”, function(this){ alert(this.val()); }); function句柄中调用的this参数 不是绑定的元素,而是bind绑定的事件
想再函数句柄中传递参数 可以采用下面的方法, 个人偏向第二种方法,代码易读、简单
1. 默认方法 event.data
想传递参数给function 可以通过data传递,function中 event.data.* 来调用
2. 全局变量
3. 内部函数
1.执行时间
window.onload 必须等到页面内所有元素(包括图片 css js等)加载完毕后才会执行。
$(document).ready() 是DOM结构绘制完毕后就执行,不必等到所有元素加载完。
2.编写个数不同
window.onload不能同时编写多个,如果有多个window.onload方法,只会执行一个。
$(document).ready()可以同时编写多个,并且都可以得到执行,根据写的顺序决定先执行哪个。
3.简化写法
window.onload没有简化写法 $(document).ready(function() {})可以简写成$(function(){});
二、bind函数的参数传递问题
bind函数的定义: $(selector).bind(event,[data,]function)
很多刚开始用jquery的同学在用bind时都会犯过此类错误 $(“#id”).bind( “click”, function(this){ alert(this.val()); }); function句柄中调用的this参数 不是绑定的元素,而是bind绑定的事件
想再函数句柄中传递参数 可以采用下面的方法, 个人偏向第二种方法,代码易读、简单
1. 默认方法 event.data
想传递参数给function 可以通过data传递,function中 event.data.* 来调用
$(“#id”).bind(“click”, { a: $(“#id”).val() } , function(){ alert(event.data.a) } );
2. 全局变量
var a = $(“#id”).val(); $(“#id”).bind(“click”, function(){alert(a)});
3. 内部函数
$(“#id”).bind(“click”, function(){Say (“id”)}); function Say(id){alert( $(“#”+id).val() )}
相关文章推荐
- Boost关于bind的使用以及函数对象和传递参数的问题
- 利用out关键字向函数传递List<T>参数遇到的问题
- 又遇到Python另外一个问题:函数作参数,怎么传递参数?
- C语言学习4: 函数返回值与传入参数,关于函数值传递和类型隐性转换,变量不同的作用域,static变量,多文件编译例如两个C文件,显示函数调用语句跳转,递归,斐波那契数列,多文件编译相同变量的问题。
- JS循环中使用bind函数的参数传递问题
- ajax异步加载中遇到的onclick无法传递中文参数问题
- AfxBeginThread函数参数传递的问题
- 结构体变量和结构体指针变量作为函数参数传递的问题
- 函数参数的传递问题(指针的指针)(转)
- 函数参数的传递问题(指针的指针)
- c++指针作为函数参数传递的问题
- 函数参数的传递问题(一级指针和二级指针)
- 从内存分配看函数参数传递问题
- 指针作为函数参数传递时需要注意的问题
- opencv 鼠标操作SetMouseCallback()函数传递用户定义参数的问题
- perl 函数参数中传递数组和引用的一些问题
- 函数参数的传递 动态内存传递问题(指针的指针)
- 指针作为函数的参数传递的问题
- js循环动态绑定带参数函数遇到的问题及解决方案[转]
- 数组作为函数参数时的传递问题