当前位置: 首页 > news >正文

模板外贸网站建设网络规划设计师教程第二版pdf

模板外贸网站建设,网络规划设计师教程第二版pdf,做请帖网站,南通网站建设 南大街目录this默认绑定隐式绑定隐式丢失显示绑定API 调用上下文new 绑定this 绑定优先级其余绑定例外对象字面量与对象属性描述符迭代器遍历this 默认绑定 默认绑定适配 独立函数调用 默认绑定 this 指向全局对象; 故直接调用函数,该函数内部的 this 即指向全…

目录

      • this
        • 默认绑定
        • 隐式绑定
        • 隐式丢失
        • 显示绑定
        • API 调用上下文
        • new 绑定
        • this 绑定优先级
        • 其余绑定例外
      • 对象
        • 字面量与对象
        • 属性描述符
        • 迭代器遍历

this


默认绑定

默认绑定适配 独立函数调用
默认绑定 this 指向全局对象;
故直接调用函数,该函数内部的 this 即指向全局对象;

以上情况针对的是非严格模式下,而严格模式下的 this 默认绑定为 undefined

function foo() {console.log(this.a);
}
var a = 2;
foo(); // 2

隐式绑定

隐式绑定格式: xxx.func() 或者 xxx.xxx.func()
无论 func()前面有多少个对象,func 的 this 指向永远是离他最近的一个对象
譬如下方代码, obj1.obj2.foo() 中 foo()的 this 就指向 obj2

function foo() {}
var obj2 = {a: 42,foo: foo,
};
var obj1 = {a: 2,obj2: obj2,
};
obj1.obj2.foo(); // 42

隐式丢失

使用函数别名套娃太多次就会造成隐式丢失现象!
如下方代码,bar 中的 foo 是直接使用了函数别名,而不是调用 foo()
最终我们使用 bar()造成了隐式丢失,在非严格模式下取得了全局对象;

可以这么理解
bar()相当于 (obj.foo)() 而不是我们想象的 obj.foo(),故前者遵照我们的默认绑定原则,必然会指向全局对象了!

function foo() {}
var obj = {a: 2,foo: foo,
};
var bar = obj.foo;
var a = 100;
bar(); // 100

显示绑定

即使用 call apply bind 进行绑定,人为指定上下文 this
如下方代码,对 foo.call 人为将 this 指向对象 obj,故调用函数 foo 后,是出结果为 2

function foo() {console.log(this.a);
}
var obj = {a: 2,
};
foo.call(obj);

硬绑定:即一旦对一个对象使用 call 或者其他函数绑定后,无论后续怎么修改都不会改变原来绑定的对象;
apply 和 call 作用一致,好好看代码,理清逻辑关系!!!

function foo(sth) {console.log(this.a + sth);return this.a + sth;
}
var obj = {a: 2,
};
var bar = function () {return foo.apply(obj, arguments);
};
var b = bar(3); //2 3
console.log(b); //5

API 调用上下文

一个很抽象的例子,使用了结构赋值的方法

function foo(el) {console.log(el, this.id);
}
var obj = {id: "hello",
};
[(1, 2, 3)].forEach(foo, obj); // 1hello 2hello 3hello

new 绑定

经典面试题:当我们使用 new 时,发生了什么?

  1. 创建(或者说构造)一个全新的对象。
  2. 这个新对象会被执行 [[Prototype]] 连接。
  3. 这个新对象会绑定到函数调用的 this。
  4. 如果函数没有返回其他对象,那么 new 表达式中的函数调用会自动返回这个新对象。

下面就是一个很简单的构造函数例子;
构造函数内部使用 this 直接指向其内部的 constructor 存储区,那么后续调用 bar.a 的时候,就是取出 constructor 存储区的内容,而非原型对象的内容

function foo(a) {this.a = a;
}
var bar = new foo(2);
console.log(bar.a); // 2

this 绑定优先级

柯里化(currying) -> 参考 bind 硬绑定
指把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术

绑定优先级: 硬绑定 > new 绑定 > 隐式绑定 > 默认绑定


其余绑定例外

当你使用 call 进行绑定的时候传入的是一个 null 或者 undefined,那么就自动使用默认绑定规则替代;
foo.call(null)

DMZ 非军事化区;
即将 this 绑定到一个空的费委托对象 DMZ 上去,不会对程序产生任何影响

function foo(a, b) {console.log(a + b);
}
var dmz = Object.create(null);
foo.apply(dmz, [2, 3]);
var bar = foo.bind(dmz, 2);
bar(3); // 2 3

对象

字面量与对象

var 创建字面量而非对象,而仅有对象才可以使用诸如长度访问、文字操作等方法;
而引擎会自动把 var 声明的字面量自动转换成对象,而无需显式构造:

var str = "helloworld"; // 字面量
console.log(str.length);

俩特例:
null 和 undefined 没有对应的构造形式,它们只有文字形式;
Date 只有构造,没有文字形式;

现在有两个取对象中属性的写法:
obj['name'] 或者 obj[0]
事实上,引擎都会先把下标转换成字符串类型然后才取,且对象中的属性名最终都会变成字符串类型
故存在 obj[0]===obj['0']


属性描述符

ES5 新增,为对象内的所有属性都配备属性描述符,使用 getOwnPropertyDescriptor 获取它们

var obj = {a: 2,
};console.log(Object.getOwnPropertyDescriptor(obj, "a"));
// { value: 2, writable: true, enumerable: true, configurable: true }

或者使用 defineProperty 人工定义属性描述符

Object.defineProperty(obj, "a", {value: 10,writable: true,configurable: true,enumerable: true,
});

属性简介
writable 决定是否可以修改属性的值
Configurable 只要属性是可配置的
enumerable 属性可否被枚举


几个常用的属性描述符操作
Object.preventExtensions 禁用为对象添加新属性
Object.seal 对象不能添加属性,亦无法重新配置或删除任何属性
Object.freeze 在 seal 基础上设置 writable:false

Object.preventExtensions(obj);
Object.seal(obj);
Object.freeze(obj);

迭代器遍历

使用内置的 @@iterator 来遍历数组
ES6 中的符号 Symbol.iterator 来获取对象的 @@iterator 内部属性

var arr = [1, 2, 3];
var it = arr[Symbol.iterator]();it.next(); // {value:1,done:false}
it.next();

http://www.yayakq.cn/news/547735/

相关文章:

  • 苏州园区网站制作公司邢台seo
  • 网站后台如何修改密码简单的网页页面设计图片
  • 成都网站建设 川icp备系统集成项目管理中级职称
  • 有哪些官方网站做的比较好网站外包维护一年多少钱
  • 义乌本地网站开发巢湖路桥建设集团有限公司网站
  • 做网站卖广告位赚钱wordpress首页文章列表只显示摘要
  • 免费在线自助建站求个免费网站好人有好报
  • 网站域名是指什么意思在线制作图片及图片处理
  • 个人备案网站用于企业网站开发安全维护
  • 做系统用什么网站网站建设明细价格表
  • sql server做网站wordpress如何登录界面
  • 常德做网站报价内设网站
  • 怎么用自己电脑做服务器发布网站吗房子设计图片
  • 网站图标ico 需要多大深圳特区建设
  • 为什么要立刻做网站网站的最终用户
  • 建设门户网站申请中国建设银行网站查询密码
  • 网站的几种提交方式wordpress 插件表单 写入数据库
  • 十大门户网站新网站快速提高排名
  • 怎么在静态网站基础上加动态哪个网站设计好
  • 网站投票功能安阳网约车准入条件
  • 男女生做恶心的网站建e网室内
  • 宁波网站建设公司哪家好临淄58同城招聘信息网
  • 网站建设公司湘潭网站专用app
  • 高端的网站开发大连做网站不错的公司
  • 如何做网站的维护和推广高端网站建设一般多少钱
  • 卓越网的企业类型和网站种类西城上海网站建设
  • 越南网站建设游戏资讯网站怎么做
  • 祁阳网站建设塘厦基础网站建设
  • 网站申请h5case是什么网站
  • 佛山家居网站全网营销怎么建立一个网站?