`
luozhonghua2014
  • 浏览: 63124 次
文章分类
社区版块
存档分类
最新评论

javascript arguments对象研究--针对jquery源码研究再研究

 
阅读更多

外部插件:

$.fn.tinytip = function(text, customOptions) {
debugger;
if (text && typeof text === 'object'){
customOptions = text;
text = customOptions.tooltip;
}

var options = $.extend({}, tooltip_options, customOptions);
options.tooltip = text;
if (typeof options.tooltip === 'object'){
options.content = options.tooltip;
options.content.hide();
}

。。。。。。

。。。。


由jquery源码而起

jQuery.extend = jQuery.fn.extend = function() {
var options, name, src, copy, copyIsArray, clone,
target = arguments[0] || {},
i = 1,
length = arguments.length,
deep = false;


// Handle a deep copy situation
if ( typeof target === "boolean" ) {
deep = target;
target = arguments[1] || {};
// skip the boolean and the target
i = 2;
}


// Handle case when target is a string or something (possible in deep copy)
if ( typeof target !== "object" && !jQuery.isFunction(target) ) {
target = {};
}


// extend jQuery itself if only one argument is passed
if ( length === i ) {
target = this;
--i;
}

。。。。。


1、在JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。arguments非常类似Array,但实际上又不是一个Array实例。可以通过如下代码得以证实(当然,实际上,在函数funcArg中,调用arguments是不必要写成funcArg.arguments,直接写arguments即可)。

Array.prototype.testArg = "test";
function funcArg() {
console.log(funcArg.arguments.testArg);
console.log(funcArg.arguments[0]);
console.log(arguments[0]);
}s
console.log(new Array().testArg); // result: "test"
funcArg(10); // result: "undefined" "10"



2、arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。如下代码可以得以验证。

function f(a, b, c){
console.log(arguments.length); // result: "2"
a = 100;
console.log(arguments[0]); // result: "100"
arguments[0] = "qqyumidi";
console.log(a); // result: "qqyumidi"
console.log(c); // result: "undefined"
c = 2012;
console.log(arguments[2]); // result: "undefined"
}
f(1, 2);



3、由JavaScript中函数的声明和调用特性,可以看出JavaScript中函数是不能重载的。根据其他语言中重载的依据:"函数返回值不同或形参个数不同",我们可以得出上述结论:

第一:Javascript函数的声明是没有返回值类型这一说法的;

第二:JavaScript中形参的个数严格意义上来讲只是为了方便在函数中的变量操作,实际上实参已经存储在arguments对象中了。

另外,从JavaScript函数本身深入理解为什么JavaScript中函数是不能重载的:在JavaScript中,函数其实也是对象,函数名是关于函数的引用,或者说函数名本身就是变量。对于如下所示的函数声明与函数表达式,其实含以上是一样的(在不考虑函数声明与函数表达式区别的前提下),非常有利于我们理解JavaScript中函数是不能重载的这一特性。


function f(a){
return a + 10;
}


function f(a){
return a - 10;
}


// 在不考虑函数声明与函数表达式区别的前提下,其等价于如下


var f = function(a){
return a + 10;
}


var f = function(a){
return a - 10;
}



4、arguments对象中有一个非常有用的属性:callee。arguments.callee返回此arguments对象所在的当前函数引用。在使用函数递归调用时推荐使用arguments.callee代替函数名本身。

function count(a){
debugger;
if(a==1){
return 1;
}
return a + arguments.callee(--a);
}


var mm = count(10);
console.log(mm); //55


分享到:
评论

相关推荐

    《精通Javascript+jQuery》光盘源码

     2.8.2 用arguments对象访问函数的参数  2.8.3 实例:杨辉三角  2.9 其他对象  2.9.1 对象简述  2.9.2 时间日期:Date对象  2.9.3 数学计算:Math对象  2.10 BOM基础  2.10.1 window对象  2.10.2 ...

    jQuery源码解读

    《jQuery源码解读:深入理解JavaScript面向对象》 在深入探讨jQuery源码之前,我们必须首先理解JavaScript中的面向对象编程概念,因为jQuery的核心机制大量运用了这一思想。面向对象编程是软件开发中的一个重要范式...

    jquery插件开发

    jQuery库是JavaScript中最广泛使用的库之一,它简化了DOM操作、事件处理、动画制作以及Ajax交互。开发jQuery插件能够帮助我们扩展其功能,满足特定项目需求。本篇将深入探讨jQuery插件的开发流程、核心概念及实践...

    jQuery自定义插件开发基础1——jQuery实用函数的实现

    这可以通过在函数内部使用`arguments`对象或设置默认值来实现。 ```javascript $.fn.myFunction = function(options) { var defaults = { param1: 'default1', param2: 'default2' }; var settings = $....

    jQery中类数组判断的实现原理及代码实现

    在实际的jQuery源码中,判断类数组对象的方式可能更为复杂,会考虑更多的边界情况和优化。例如,jQuery可能会检查`slice`方法是否存在,因为所有数组(包括类数组)都应支持`slice`,这可以作为一个更可靠的判断依据...

    javascript权威指南(第六版)

    包含英文和中文两个版本附有本书源码. Preface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xiii 1. Introduction...

    jQuery 1.9.1源码分析系列(十)事件系统之绑定事件

    jQuery作为一个流行的JavaScript库,为开发者提供了简单易用的方法来处理事件。在本分析中,将详细介绍jQuery 1.9.1版本中事件绑定的多种方法及其背后的机制。 1. 直接绑定事件 直接绑定事件是最基础的绑定方式,...

    jquery事件绑定解绑机制源码解析

    ery.event.handle.apply...通过阅读源码,我们可以看到JQuery如何通过缓存和队列管理事件,以及如何通过代理模式实现一次性事件处理。这加深了我们对JQuery内部运作的理解,使我们能够更好地优化我们的JavaScript代码。

    underscore1.5.2中文帮助

    - 与jQuery不同的是,Underscore不扩展任何JavaScript内置对象,比如Array或Function。 - Underscore被认为是Backbone.js框架的一个必要组成部分,同时也弥补了jQuery未实现的功能。 2. **Underscore的主要功能**...

    js设计模式源码

    <script type="text/javascript" src="js/jquery.js"> <h2>Media(中介者)模式 行为设计模式。公开一个统一的接口,系统的不同部分可以通过该接口进行通信。 确保组件的交互是通过这个中心点来处理,而...

    liveQuery源码

    ### liveQuery源码解析 #### 一、简介 liveQuery是一个强大的jQuery插件,它能够为动态添加到DOM中的元素绑定事件,而不需要重新选择这些元素。这在处理频繁变化的DOM元素时非常有用,例如AJAX加载的内容或通过...

    javascript 伪数组实现方法

    典型的伪数组包括DOM方法返回的NodeList对象,如document.getElementsByTagName()和document.childNodes等返回的元素集合,以及JavaScript函数内部的arguments对象。 ### 实现伪数组转数组的方法 在JavaScript中,...

    javascript 构造函数强制调用经验总结

    作者建议有兴趣深入了解的读者可以进一步探索jQuery源码,了解其内部实现原理。 总的来说,构造函数的正确调用对于确保对象属性能够被正确创建和初始化至关重要。在实际开发中,为了避免未使用new操作符而导致的...

    javascript笔记 String类replace函数的一些事

    通过深入理解`String.replace()`函数的这些细节,可以更有效地进行字符串处理和模式匹配,这对于学习和理解JavaScript,尤其是复杂的库如jQuery的源码至关重要。掌握这些高级用法能够帮助开发者编写出更加灵活和强大...

    IE、FF的JS兼容写法

    在JavaScript编程中,IE(Internet Explorer)和FF(Firefox)是两种主要的浏览器,它们对JS(JavaScript)的实现存在一些差异,导致某些代码在其中一个浏览器中可能无法正常工作。这篇博客文章“IE、FF的JS兼容写法...

    JS 组件系列之Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案

    总之,通过深入理解Bootstrap Table的内部工作机制,我们可以针对性地修改源码,解决在IE浏览器中的兼容性问题。虽然这可能不是最理想的方法,但在某些情况下,特别是在维护旧项目时,这种方法可能是最有效且可行的...

Global site tag (gtag.js) - Google Analytics