js高级知识讲解

本文主要和大家分享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高级知识讲解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2777914.html

(0)
上一篇 2025年3月8日 15:16:11
下一篇 2025年3月2日 23:51:44

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js的箭头函数简介

    箭头函数就是个简写形式的函数表达式,并且它拥有词法作用域的this值(即不会新产生自己作用域下的this,arguments,super和new.target等对象)。此外,箭头函数总是匿名的。 基础语法 (param1, param2, …

    编程技术 2025年3月8日
    200
  • 深入理解js数据类型

    本文主要和大家分享深入理解js数据类型, 在 ECMAScript 规范中,共定义了 7 种数据类型,分为 基本类型 和 引用类型 两大类,如下所示: 基本类型:String、Number、Boolean、Symbol、Undefined、…

    2025年3月8日 编程技术
    200
  • js实现获取网络类型的方法

    本文主要和大家分享js实现获取网络类型的方法,主要以代码的方式,希望能帮助到大家。    function getNetworkType() {            var ua = navigator.userAgent;       …

    编程技术 2025年3月8日
    200
  • js关于时间转换问题分享

    本文主要和大家分享js关于时间转换问题分享,主要以代码的形式和大家讲解,希望能帮助到大家。 1.js字符串转换成时间 1.1方法一:输入的时间格式为yyyy-mm-dd function convertDateFromString(date…

    编程技术 2025年3月8日
    200
  • js鼠标键盘无操作实例

    本文主要和大家分享js鼠标键盘无操作实例,主要以代码的方式和大家分享,希望能帮助到大家。 var count = 0; var outTime=30;//分钟 window.setInterval(go, 1000); function g…

    编程技术 2025年3月8日
    200
  • JS中的内置对象Array详解

    本文主要和大家分享JS中的内置对象Array详解,JS的内置对象主要分为四大类:Array  String  Math  Date,我们主要介绍Array,希望能帮助到大家。 Array  数组内的每一项都可以保存任意类型的数据,数组的大小…

    编程技术 2025年3月8日
    200
  • JS的内置对象String详解

    JS的内置对象主要分为四大类:Array  String  Math  Date,本文主要和大家分享JS的内置对象String详解,希望能帮助到大家。 String 主要介绍一些方法的使用: 1. charAt( )     stringO…

    编程技术 2025年3月8日
    200
  • 原声js实现放大镜效果

    本文主要和大家分享原声js实现放大镜效果,主要以代码的方式和大家分享,希望能帮助到大家。 nbsp;html>*{margin: 0;padding:0}.mg{height:577px;width:352px;margin-left…

    编程技术 2025年3月8日
    200
  • 容易产生错误的js手机号码验证

    这次给大家带来容易产生错误的js手机号码验证,容易产生错误js手机号码验证的注意事项有哪些,下面就是实战案例,一起来看一下。 写一个简单的正则表达式,用来校验11位手机号码,开头允许是13、15、18,我一开始这样写: var reg = …

    编程技术 2025年3月8日
    200
  • 使用正则表达式在js里怎么查找字母与数字

    这次给大家带来使用正则表达式在js里怎么查找字母与数字,使用正则表达式在js里查找字母与数字的注意事项有哪些,下面就是实战案例,一起来看一下。 废话不多说,先看下js中使用正则查找字母和数字的方法,具体代码如下所示: window.onlo…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论