最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

js高级知识讲解

来源:动视网 责编:小采 时间:2020-11-27 19:57:50
文档

js高级知识讲解

js高级知识讲解:本文主要和大家分享js高级知识讲解继承继承是类型与类型之间的关系;对象的继承:实际上是对对象的拷贝function extend (parent, child) { for (var key in parent) { if (! child[key] ) { child[key] = parent[key]
推荐度:
导读js高级知识讲解:本文主要和大家分享js高级知识讲解继承继承是类型与类型之间的关系;对象的继承:实际上是对对象的拷贝function extend (parent, child) { for (var key in parent) { if (! child[key] ) { child[key] = parent[key]


本文主要和大家分享js高级知识讲解

继承

继承是类型与类型之间的关系;

对象的‘继承’:

实际上是对对象的拷贝

function extend (parent, child) 
{ for (var key in parent) 
{ if (! child[key] )
{ child[key] = parent[key] 
} 
}}

原型继承

只能继承父元素中的方法,属性继承没有意义

//父级元素function Person (name, age, sex)
{ this.name = name; this.age = age; 
this.sex = sex}Person.prototype.sayHi = function ()
{ console.log('hello' + this.name);}
//子级元素function Student (score) 
{ this.score = score;}
//只能继承方法Student.prototype = new Person;Student.prototype.constructor = Student;var s1 = new Student(100);console.log(s1);

注意:

问题:无法给构造函数设置参数 Student.prototype = new Person ,且只能执行一次,无法给属性传值;

借用构造函数

利用call能改变this的属性,并且可以借用构造函数,但是不能继承构造函数的方法;

//父级元素function Person (name, age, sex)
{ this.name = name; this.age = age; this.sex = sex}Person.prototype.sayHi = function ()
{ console.log('hello' + this.name);}
//子级元素function Student (name,age, sex, score) {Person.call(this, name, age, sex); 
this.score = score;}
//只能继承属性var s1 = new Student('na', 20, 'nv' , 100);console.log(s1);

原型+ 构造函数

把原型和构造函数两种情况结合:但会出现一个问题,一个子级元素的方法会被多个子级元素访问;

如何解决这个问题,则用到了对象的继承即拷贝;

function extend (parent, child) 
{ for (var key in parent) 
{ if (! child[key] )
{ child[key] = parent[key] 
 } }}function Person (name, age, sex)
 { this.name = name; this.age = age; 
 this.sex = sex}Person.prototype.sayHi = function ()
 { console.log('hello' + this.name); }
 //子级元素function Student (name,age, sex, score) 
 {Person.call(this, name, age, sex); 
 this.score = score;}Student.prototype.say = function ()
 { console.log('hi'); }
 //只能继承属性extend(Person.prototype, Student.prototype);var s1 = new Student('na', 20, 'nv' , 100);console.log(s1);
 //子级元素function Teacher (name,age, sex,salary) {Person.call(this, name, age, sex); this.salary = salary}extend(Person.prototype, 
 Teacher.prototype);var t = new Teacher('na', 10,'nv', 1000);console.log(t);

函数进阶

函数的定义方式

1.函数声明

function fn() {

}

2.函数表达式

var fn = function (){

}

3.var fn = new Function('参数是字符串');

这里的fn即使对象又是函数

4.函数声明与函数表达式的区别

函数声明会提升,在前后都能调用,而函数表达式只能在函数表达式后面调用

应用到this的场景

1.构造函数中的this指向调用的对象

2.普通函数中的this指向window,严格模式下指向undefined;

3.定时器中的this指向window

4.对象方法调用this指向调用方法的对象

改变this的指向

1.bind:

第一个参数指向this要指向的元素;

返回一个新的函数;

2.call

会调用函数,改变this的指向

借用构造函数

借用其他对象的方法

3.apply

第一个参数是改变的this的指向,第二个参数是一个数组;

相关推荐:

JS高级相关知识

文档

js高级知识讲解

js高级知识讲解:本文主要和大家分享js高级知识讲解继承继承是类型与类型之间的关系;对象的继承:实际上是对对象的拷贝function extend (parent, child) { for (var key in parent) { if (! child[key] ) { child[key] = parent[key]
推荐度:
标签: 知识 讲解 js
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top