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笔记的更多相关文章

  1. Deep Learning深入研究整理学习笔记五

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  2. 看Web视频整理标签笔记

    原来观看web视频,初学html的时候发现记忆不太深刻,所以自己整理了一些笔记,加深记忆且方便忘记时查看.html的规范(遵循)1.一个html文件开始标签和结束标签<html></ ...

  3. geodjango七日学习笔记 (7.30整理本地笔记上传到网络)

    第一天进行到现在,在开端的尾巴,想起来写一个学习笔记, 开发环境已搭好,用的是pycharm 环境是本机已有的interpreter python3.7   接下来要做的是新建一个geodjango项 ...

  4. 辛星整理3linux笔记,免费下载点,我希望对你有所帮助

    忙乱,这是我第一次看李指出老师的视频时,,这本书是关于116页面,在csdn下载对:点我下载 ,假设左边的地址崩溃了,也能够在浏览器中输入例如以下地址然后下载:http://download.csdn ...

  5. [IOS 开发] NSDateFormatter的格式字符串 -- 《整理的笔记》

    在ios开发中, OBjective-C中的NSDate是一个挺讨厌的类型, 自己找不到转换成字符串的类型,还得带一个NSDateFormatter的类型. 官方文档上对NSDateFormatter ...

  6. 整理课堂笔记 pl/sql orcale异常

      1>>>>>异常错误处理 1 >预定义的异常处理 预定义说明的部分 ORACLE 异常错误对这种异常情况的处理,只需在PL/SQL块的异常处理部分,直接引用相应 ...

  7. iframe整理学习笔记

    朋友问了一个比较怪的问题,iframe下自适应的问题,因为很少使用iframe的原因,怀着对iframe的疑惑采用了一点点实践;以下frame表示针对的iframe元素 解决的方法:对iframe进行 ...

  8. JavaScript匿名类整理学习笔记

    以下为总结在开源的JavaScript框架中能看到很多这样语法结构(function(){})()比如我最近看的jQuery,及chediter.刚开始的时候我看到这样的结果有点奇怪,它是怎么执行的, ...

  9. django--没有整理,笔记

    https://docs.djangoproject.com/en/2.2/常用的数据路命令:python manage.py makemigrations 数据移植准备python manage.p ...

随机推荐

  1. mysql避免数据库误操作小技巧(转)

    避免混淆开发环境的DB和生产环境的DB这在小公司小团队尤其常见.一个人即负责开发,又管DB.桌面上开了一坨终端,有的是开发的DB,有的是生产的DB.一不留神,就写串了,或者粘贴串了.更郁闷的是,有时候 ...

  2. C# 让String.Contains忽略大小写

    在C#里,String.Contains是大小写敏感的,所以如果要在C#里用String.Contains来判断一个string里是否包含一个某个关键字keyword,需要把这个string和这个ke ...

  3. orange---openresty.

    需要有一个类似于API网关的中间件来做API的管理工作,也就是API的实现方面更多的考虑业务逻辑,安全.性能.监控可以交由网关来做(如下图所示,下图根据Kong官方文档修改) 通过MySQL存储来简单 ...

  4. LeetCode 520 Detect Capital 解题报告

    题目要求 Given a word, you need to judge whether the usage of capitals in it is right or not. We define ...

  5. Unable to convert MySQL date/time value to System.DateTime问题解决方案

    原因:可能是该字段(date/datetime)的值默认缺省值为:0000-00-00/0000-00-00 00:00:00,这样的数据读出来转换成System.DateTime时就会有问题: 解决 ...

  6. 注解@RestController与@Controller的区别

    开发RESTful API 时,一般都会在Controller上加上@Controller注解,但是有时候加上@RestController,当同事问为什么的时候,我也一脸懵逼,默默的看了资料,现在就 ...

  7. Java-idea-安装配置优化等

    1.属性配置 使用版本,winzip解压版,开发工具安装目录下idea.properties文件,自定义配置路径 # idea.config.path=${user.home}/.IntelliJId ...

  8. CSS-对于IE的兼容问题处理

    css兼容问题 兼容问题 1.文字本身的大小不兼容.同样是font-size:14px的宋体文字,在不同浏览器下占的空间是不一样的,ie下实际占高16px,下留白3px,ff下实际占高17px,上留白 ...

  9. 【LeetCode每天一题】Combinations(组合)

    Given two integers n and k, return all possible combinations of k numbers out of 1 ... n. Example: I ...

  10. 本地node启动服务步骤

    启动node服务: 1.git bash here (node server-run.js) 2.如果第一次启动node服务,要根据提示装依赖文件npm install 依赖文件名 3.启动成功提示: ...