js的继承(一)

继承Array

  1. 原型继承
function Arr(...args){
    args.forEach(item=>this.push(item))
    this.first = function(){
        return this[0]
    }
    this.max = function(){
        return this.sort((a,b)=>b-a)[0]
        //注意:sort会改变原数组的顺序
    }
}
Arr.prototype = Object.create(Array.prototype)
let a = new Arr(1,2,99,3,4)

console.log(a) //[1, 2, 99, 3, 4]
console.log(a.max()) //99
  1. 类继承
class Arrc extends Array{
    constructor(...args){
        super(...args)
    }
    first(){
        return this[0]
    }
    max(){
        return this.sort((a,b)=>b-a)[0] 
        //注意:sort会改变原数组的顺序
    }
}
let b = new Arr(48,9,0,2,2)

console.log(b) //[48, 9, 0, 2, 2]
console.log(b.max()) //48
console.log(b) //[48, 9, 2, 2, 0]
  1. mixin 混合继承
//mixin 混合继承
class Lesson{
    constructor(lessons){
        this.lessons = lessons
    }
    get data(){
        return this.lessons
    }
}
const data = [
    {name:'js',price:200},
    {name:'css',price:199},
    {name:'python',price:201}
]
let Tool = {
    max(key){
        return this.data.sort((a,b)=>b[key]-a[key])[0]
}}
let Cont = {
    total(key){
        return this.data.reduce((t,c)=>t+c[key],0)
    }
}
//原型上追加属性
Object.assign(Lesson.prototype,Tool,Cont)
console.dir(Lesson)
let zz = new Lesson(data)
console.log(zz.max('price')) //{name: "python", price: 201}
console.log(zz.total('price')) //600
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值