本文目录
- 能否详解这个语法
- javascript中offset什么意思啊如下arguments.callee.offset中offset的具体含义是什么啊,求详解!
- There are some good arguments for a technical education given the right kind of student.这句
- this.method.apply 这样的用法是什么意思
能否详解这个语法
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 的区别。
希望对你有帮助