×

arguments用法详解

arguments用法详解(能否详解这个语法)

admin admin 发表于2024-06-16 08:19:39 浏览22 评论0

抢沙发发表评论

大家好,如果您还对arguments用法详解不太了解,没有关系,今天就由本站为大家分享arguments用法详解的知识,包括能否详解这个语法的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

本文目录

能否详解这个语法

arguments就是你传入函数中的参数,以上面为例,arguments就是123,以此类推(实际上一般比较少这样用,通常是以传入数组居多)var i, max = arguments;//将每一个元素(也就是1)赋值给maxif(arguments.length 《 2) return max; //如果只传入了一个参数,则直接返回//arguments.length 也就是传入参数的总个数,上面示例中为6个for (i = 0; i 《 arguments.length; i++) { //循环处理每个参数if (arguments 》 max) { //判断每个参数是否大于maxmax = arguments;//如果是的话,刚将最大数赋给max}}return max;//循环完成后,返回最大值}

javascript中offset什么意思啊如下arguments.callee.offset中offset的具体含义是什么啊,求详解!

/*不知道楼主的程序是要做什么……不过我看到offset首先想到css的偏移量。callee 属性是 arguments 对象的一个成员,该属性仅当相关函数正在执行时才可用。callee 属性的初始值是正被执行的 Function 对象。这将允许匿名函数成为递归的。*//*IE、Firefox3及更高和Opera9.5及更高为每一个元素提供了一个getBoundingClientRect()方法。这个方法返回一个矩形对象,含4个属性:left、top、right和bottom。这些属性给出了元素在页面中相对于视口的位置。但IE认为左上角坐标为(2,2),其他浏览器认为是(0,0)。*/ //所以我用过的方法是这样的(获取元素大小):function getBoundingClientRect(element){ var scrollTop = document.documentElement.scrollTop; var scrollLeft = document.documentElement.scrollLeft;     if(element.getBoundingClientRect){         If(typeof arguments.callee.offset != "number"){             var temp = document.createElement("div");             temp.style.cssText = "position:absolute;left:0;top:0;";             document.body.appendChild(temp);             arguments.callee.offset = -temp.getBoundingClientRect().top - scrollTop;             document.body.removeChild(temp);             temp = null;         }             var rect = element.getBoundingClientRect();         var offset = arguments.callee.offset;             return{             left: rect.left + offset,             right: rect.right + offset,             top: rect.top + offset,             bottom: rect.bottom + offset         };     }else{         var actualLeft = getElementLeft(element);         var actualTop = getElementTop(element);             return{             left: actualLeft - scrollLeft,             right: actualLeft + element.offsetWidth - scrollLeft,             top: actualTop - scrollTop,             bottom: actualTop + element.offsetHeight - scrollTop         }     } }

There are some good arguments for a technical education given the right kind of student.这句

There are some good arguments for a technical education given the right kind of student. 完全可以,看成状语即可。given在这句话中的用法相当于if,但given可以后面接句子也可以接名词词组;eg.I am sensible with money, as I have to be, given that I don’t earn that much. 考虑到自己挣得不多,我用钱通常比较精打细算,这也是迫不得已。【接句子】 given patience, successful breeding of this species can be achieved. 只要有耐心,是能成功培育出这一品种的。 【接名词】

this.method.apply 这样的用法是什么意思

  • 你好,this.method.apply(this, arguments) 传参 this,只是一个引用对象,可以是apply的调用对象,也可以是 this.method.apply(new Object(), arguments),说明调用apply的 this 中的 this 为 new Object(),这就说明了,当 var a = new Object(); this.method.apply(a, arguments); 时,就相当于 a.method(arguments) ,而不再是 this.method(arguments)

  • 简单一句,这是一个借用别人方法来调用,自己就不用写这个方法了

  • 区别在于,apply 的第二个参数是 array like object,可以用来传递不确定个数的参数。用 this.method 做不到。

  • arguments 并不是随便取的一个变量名,而是一个保留字,代表程序执行时所在函数传进来的所有参数,是一个类似于数组的对象(可以通过 arguments 取得值,可以用 arguments.length 获得长度,但是没有数组的 slice split 等方法)。arguments 的长度取决于, 当前函数(arguments.callee ,此例中是调用 this.method 的“父级函数” )在执行时传进来的参数数量。所以当我们想设计比较灵活的API,需要不确定参数个数的函数时,它就特别有用。

  • this.method(arg1) 相当于 this.method.call(this, arg1) ,即只向 this.method 传了一个变量。

  • this.method.apply(this, args) 的时候,args 必须是一个数组(或者像 arguments 一样有 length 和 0, 1, 2, 3.. 索引的对象)。这也是 call 和 apply 的区别。

希望对你有帮助

以上就是我们为大家找到的有关“arguments用法详解(能否详解这个语法)”的所有内容了,希望可以帮助到你。如果对我们网站的其他内容感兴趣请持续关注本站。