详解jquery插件中;(function ( $, window, document, undefined )的作用
2015-12-10 10:33
585 查看
在jquery插件中我们经常看到以下这段代码
对于很多初学者来说很难明白这表示什么,下边我将为大家介绍其相应的作用。
1、代码最前面的分号,可以防止多个文件压缩合并以为其他文件最后一行语句没加分号,而引起合并后的语法错误。
2、匿名函数(function(){})();:由于Javascript执行表达式是从圆括号里面到外面,所以可以用圆括号强制执行声明的函数。避免函数体内和外部的变量冲突。
3、$实参:$是jquery的简写,很多方法和类库也使用$,这里$接受jQuery对象,也是为了避免$变量冲突,保证插件可以正常运行。
4、window, document实参分别接受window, document对象,window, document对象都是全局环境下的,而在函数体内的window, document其实是局部变量,不是全局的window, document对象。这样做有个好处就是可以提高性能,减少作用域链的查询时间,如果你在函数体内需要多次调用window 或 document对象,这样把window 或 document对象当作参数传进去,这样做是非常有必要的。当然如果你的插件用不到这两个对象,那么就不用传递这两个参数了。
5、最后剩下一个undefined形参了,那么这个形参是干什么用的呢,看起来是有点多余。undefined在老一辈的浏览器是不被支持的,直接使用会报错,js框架要考虑到兼容性,因此增加一个形参undefined
1、代码最前面的分号,可以防止多个文件压缩合并以为其他文件最后一行语句没加分号,而引起合并后的语法错误。
2、匿名函数(function(){})();:由于Javascript执行表达式是从圆括号里面到外面,所以可以用圆括号强制执行声明的函数。避免函数体内和外部的变量冲突。
3、$实参:$是jquery的简写,很多方法和类库也使用$,这里$接受jQuery对象,也是为了避免$变量冲突,保证插件可以正常运行。
4、window, document实参分别接受window, document对象,window, document对象都是全局环境下的,而在函数体内的window, document其实是局部变量,不是全局的window, document对象。这样做有个好处就是可以提高性能,减少作用域链的查询时间,如果你在函数体内需要多次调用window 或 document对象,这样把window 或 document对象当作参数传进去,这样做是非常有必要的。当然如果你的插件用不到这两个对象,那么就不用传递这两个参数了。
5、最后剩下一个undefined形参了,那么这个形参是干什么用的呢,看起来是有点多余。undefined在老一辈的浏览器是不被支持的,直接使用会报错,js框架要考虑到兼容性,因此增加一个形参undefined
相关文章推荐
- Jquery之AJAX COOKIES跨域请求 - JSONP实现方法
- jquery发送参数
- jquery源码中ajax方法理解之十五问
- jquery.autocomplete.js 插件的自定义搜索规则
- jquery实现鼠标悬浮停止轮播特效
- jquery实现定时自动轮播特效
- jQuery手动点击实现图片轮播特效
- jquery点击改变class并toggle
- Jquery easyui从零单排之datagrid排序
- jquery判断复选框是否选中进行答题提示特效
- jQuery手动点击实现图片轮播特效
- jquery实现定时自动轮播特效
- jquery实现鼠标悬浮停止轮播特效
- jQuery实现监控页面所有ajax请求的方法
- jQuery自定义动画函数实例详解(附demo源码)
- SpringMVC框架下JQuery传递并解析Json格式的数据是如何实现的
- 基于jQuery实现复选框是否选中进行答题提示
- jquery判断复选框是否选中进行答题提示特效
- 关于javascript 以及 jQuery中获取文本值得一点看法
- jquery制作一个简单的日历