博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
javascript arguments对象研究--针对jquery源码研究再研究
阅读量:5788 次
发布时间:2019-06-18

本文共 2609 字,大约阅读时间需要 8 分钟。

外部插件:

 $.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

转载地址:http://cgqyx.baihongyu.com/

你可能感兴趣的文章
《架构之美》摘录三
查看>>
myeclipse6.5上基于JAX-WS开发Webservice(中文示例)
查看>>
HTML基础(一)
查看>>
谈谈冒烟测试
查看>>
boost.circular_buffer简介
查看>>
Database Appliance并非Mini版的Exadata-还原真实的Oracle Unbreakable Database Appliance
查看>>
CORTEX-M3 异常/中断控制(使能和除能)
查看>>
网页图片缩放(js)
查看>>
没有设计模式画小人,有趣画板
查看>>
简易高负载进程记录脚本
查看>>
在VMware上安装CentOS-6.5 minimal - 安装VMware Tools
查看>>
使用 Xtrabackup 在线对MySQL做主从复制
查看>>
linux sort/uniq 使用
查看>>
enq: TT - contention等待事件
查看>>
【资料整理】git的使用
查看>>
python第三方模块—psutil模块
查看>>
Latches and Tuning:Latches
查看>>
Oracle OSW安装
查看>>
hadoop伪分布式2.4.1安装
查看>>
设置title图标
查看>>