博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript链式调用,对象属性与遍历,this指向,callee和caller
阅读量:6952 次
发布时间:2019-06-27

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

链式调用

var sched = {

wakeup: function(){

....

return this;

}

noon: function(){

....

return this;

}

night : function(){

....

return this; //是关键

}

}

链式调用:sched.wakeup().noon().night()

对象属性

obj["属性名"]

对象枚举

for in

hasOwnProperty

for in 会遍历出原型链上所有属性,hasOwnProperty可以判断是不是自身的属性

hasOwnProperty 排除原型链

A instanceof B A对象的原型里到底有没有B的原型,有就返回true

判断是否是数组的方法:

var a = [];

var str = Object.prototype.toString.call(a);

if(str === '[object Array]'){

console.log('是数组');

}else{

console.log('不是数组')

}

this

函数内部的this 运行以后指向window,若是实例化则指向实例化对象

call和apply的this

全局this->window

预编译函数this ->window

apply/call改变this指向

构造函数的this指向实例化对象

实例化的过程中 会var this = {__proto__:Test.prototype}

callee/caller

ex1:

function test(a, b, c){

console.log(arguments.callee.length); //3

console.log(test.length); //3

console.log(arguments.length); //2

}

test(1,2);

ex2:

var sum = (function(n){

if(n <= 1){

return 1;

}

return n + arguments.callee(n - 1);

})(100);

console.log(sum)

ex3:

caller

test1();

function test1(){

test2();

}

function test2(){

console.log(test2.caller); //返回当前被调用函数的函数引用

}

如果'use strict',caller、callee和arguments都不能通过

转载于:https://juejin.im/post/5b793820e51d4538ce434558

你可能感兴趣的文章
Eclipse设置智能提示
查看>>
SAP 生产订单变更管理 OCM Order Changement Management
查看>>
虚拟化这八年-【软件和信息服务】2014.11
查看>>
使用swfupload上传超过30M文件,使用FLASH上传组件
查看>>
OkHttp简介
查看>>
如何使用通用Mapper
查看>>
MYSQL建表语法(主键,外键,联合主键)
查看>>
linux基础-第十单元 系统的初始化和服务
查看>>
多线程的通信和同步(Java并发编程的艺术--笔记)
查看>>
Python格式化输出
查看>>
Linux使用du和df查看磁盘和文件夹占用空间
查看>>
java 消息机制 ActiveMQ入门实例
查看>>
CentOS 6.6 MySQL install
查看>>
从零开始用gulp
查看>>
android之Activity的生命周期
查看>>
hadoop2.4 支持snappy
查看>>
java 又一次抛出异常 相关处理结果演示样例代码
查看>>
STL 笔记(四) 迭代器 iterator
查看>>
2017"百度之星"程序设计大赛 - 复赛1003&&HDU 6146 Pokémon GO【数学,递推,dp】
查看>>
开源倾情奉献:基于.NET打造IP智能网络视频监控系统
查看>>