整理this笔记
1.在浏览器全局环境中this指向的是Window
console.log(this); //Window
2.在事件处理函数中的this,这个事件是由谁触发,this就指向谁
3.直接执行一个函数的时候在非严格模式下this指向的是Window,而在严格模式下是undefined
function fn1() {
"use strict"
console.log(this); //undefined
}
function fn2() {
console.log(this); //Window
}
fn1();
fn2(); //相当于window.fn2();
4.关于call,apply,和bind的this
他们的作用是把this的值从一个执行环境传入到另外一个执行环境
call和apply的区别只在于参数不同,call的参数后面可以是很多个的,而apply只能是俩个参数,后面一个参数是数组
function fn(x) {
console.log(this.a + x); //
}
fn.call({a:1},2);//第一个实参是对象,要改变this指向的对象,后面是你想要传的参数
如果传入的不是对象会调用相应的构造函数,进行隐式转换
function fn(x) {
console.log(this); //Number{1}
}
fn.call(1); //bind和apply也一样
bind他会返回一个新的函数,改变这个新函数的执行,而且这个函数只会执行一次bind
function fn() {
console.log(this.a); //
}
fn.bind({a:1})(); //返回一个新的函数,所以你要在执行这个返回的函数才会得到结果打印出1,不能在点bind
5.箭头函数里的this是与你定义的环境this一样的,并且使用call,apply和bind是改变不了箭头函数里的this
在全局中定义一个箭头函数,他指向的是Window
var fn = () => {
console.log(this); //Window
}
fn();
在对象里定义一个箭头函数,他跟这个对象的环境是一样的
var a = 1;
var obj = {
a:2,
fn1:() => {
console.log(this.a) //
},
fn2:function () {
console.log(this.a);//
}
}
obj.fn1();
obj.fn2();
在对象里返回一个箭头函数,他还是和对象的环境一样
var a = 1;
var obj = {
a:2,
fn1:() => {
return ()=>{
console.log(this.a);
}
},
fn2:function () {
return function(){
console.log(this.a);
}
}
}
obj.fn1()(); //
obj.fn2()(); //
6.构造函数
构造函数里没有显式return
在构造函数中如果写return一个是对象,一个是非对象
当你返回一个对象的时候,实例化的结果就是这个对象
当你返回一个非对象的时候,实例化的结果就是这个构造函数
function Fn() {
this.a = 1;
return {}; // {}
return ""; // Fn(){a:1}
}
var fn = new Fn();
console.log(fn);
7.getter和setter,setter会自动刷新改变的数据
var obj = {
a : 1,
b : 2,
get sum(){
console.log("getter...");
return this.a + this.b;
},
set sum(x){
console.log("setter...");
this.a = x*2;
this.b = x*3;
}
} console.log(obj.sum = 4); //setter... 4
console.log(obj.a); //
整理this笔记的更多相关文章
- Deep Learning深入研究整理学习笔记五
Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...
- 看Web视频整理标签笔记
原来观看web视频,初学html的时候发现记忆不太深刻,所以自己整理了一些笔记,加深记忆且方便忘记时查看.html的规范(遵循)1.一个html文件开始标签和结束标签<html></ ...
- geodjango七日学习笔记 (7.30整理本地笔记上传到网络)
第一天进行到现在,在开端的尾巴,想起来写一个学习笔记, 开发环境已搭好,用的是pycharm 环境是本机已有的interpreter python3.7 接下来要做的是新建一个geodjango项 ...
- 辛星整理3linux笔记,免费下载点,我希望对你有所帮助
忙乱,这是我第一次看李指出老师的视频时,,这本书是关于116页面,在csdn下载对:点我下载 ,假设左边的地址崩溃了,也能够在浏览器中输入例如以下地址然后下载:http://download.csdn ...
- [IOS 开发] NSDateFormatter的格式字符串 -- 《整理的笔记》
在ios开发中, OBjective-C中的NSDate是一个挺讨厌的类型, 自己找不到转换成字符串的类型,还得带一个NSDateFormatter的类型. 官方文档上对NSDateFormatter ...
- 整理课堂笔记 pl/sql orcale异常
1>>>>>异常错误处理 1 >预定义的异常处理 预定义说明的部分 ORACLE 异常错误对这种异常情况的处理,只需在PL/SQL块的异常处理部分,直接引用相应 ...
- iframe整理学习笔记
朋友问了一个比较怪的问题,iframe下自适应的问题,因为很少使用iframe的原因,怀着对iframe的疑惑采用了一点点实践;以下frame表示针对的iframe元素 解决的方法:对iframe进行 ...
- JavaScript匿名类整理学习笔记
以下为总结在开源的JavaScript框架中能看到很多这样语法结构(function(){})()比如我最近看的jQuery,及chediter.刚开始的时候我看到这样的结果有点奇怪,它是怎么执行的, ...
- django--没有整理,笔记
https://docs.djangoproject.com/en/2.2/常用的数据路命令:python manage.py makemigrations 数据移植准备python manage.p ...
随机推荐
- linux命令:压缩解压打包工具大集合
目录 (1)zip 压缩.解压缩及归档工具有很多,今天小编就整理几个大家较为常用的. compress gzip bzip2 xz zip tar cpio 一.压缩.解压工具 用法 压缩 工具 压 ...
- 20165317 java学习总结
20165317 java学习总结 每周作业链接汇总 预备作业1:https://www.cnblogs.com/ningxinyu/p/8341213.html 预备作业2:https://www. ...
- [js]浏览器同源策略(same-origin policy)
浏览器的同源策略 浏览器同源政策及其规避方法 什么是同源策略 A网页设置的 Cookie,B网页不能打开,除非这两个网页"同源".所谓"同源"指的是" ...
- Python数据分析与挖掘常用模块
python在数据科学方面需要用到的库: a.Numpy:科学计算库.提供矩阵运算的库. b.Pandas:数据分析处理库 c.scipy:数值计算库.提供数值积分和常微分方程组求解算法.提供了一个非 ...
- Java 基础 IO
一,前言 回想之前写过的程序,数据都是在内存中,一旦程序运行结束,这些数据都没有了,等下次再想使用这些数据,可是已经没有了.那怎么办呢?能不能把运算完的数据都保存下来,下次程序启动的时候,再把这些数据 ...
- Docker:从引擎和运行框架理解Docker(3)
Docker是GO语言编写的. 1.Docker发挥的作用: 1.快速.一致.标准化的交付应用.从开发.测试.到部署交付到成产环境都可以使用docker命令处理image到不同的环境 2.部署和扩展: ...
- Software Testing, Lab 1
1.Install Junit(4.12), Hamcrest(1.3) with Eclipse 2.Install Eclemma with Eclipse 3.Write a java prog ...
- 安装archlinux的linux命令记录
磁盘的分区:cfdisk 格式化分区:mkfs.ext4,mkswap,swapon 查看所有分区:lsblk /dev/sda 先挂载 / 分区:mount /dev/sda1 /mnt archl ...
- CentOS 7 配置Tomcat9连接MySQL
配置Tomcat 首先安装Tomcat 安装Tomcat分为安装Tomcat和安装JDK两个步骤 JDK( Java Development Kit ) 是Sun Microsystems针对Java ...
- 2440nandflash启动过程再学习
2011-02-13 12:27:05 2440nandflash启动,先是nandflash的前4K自动复制到CPU的0x0地址开始的4K区域. 然后CPU开始运行这4K(刚才copy过来的代码), ...