Sunny-117 / js-challenges

✨✨✨ Challenge your JavaScript programming limits step by step

Home Page:https://juejin.cn/column/7244788137410560055

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

实现es6的set集合

Sunny-117 opened this issue · comments

class MySet {
  constructor(iterator = []) {//不传默认空数组
    if (typeof iterator[Symbol.iterator] !== "function") {
      throw new TypeError(`你提供的${iterator}不是一个可迭代的对象`)
    }
    this._datas = [];
    for (const item of iterator) {
      this.add(item);
    }
  }

  get size() {
    return this._datas.length;
  }

  add(data) {
    if (!this.has(data)) {// 不包含data,才加入
      this._datas.push(data);
    }
  }

  has(data) {// 是否有data
    for (const item of this._datas) {
      if (this.isEqual(data, item)) {// isEqual判断两个数据是否相等
        return true;
      }
    }
    return false;
  }
  delete(data) {
    for (let i = 0; i < this._datas.length; i++) {
      const element = this._datas[i];
      if (this.isEqual(element, data)) {
        //删除
        this._datas.splice(i, 1);
        return true;
      }
    }
    return false;
  }

  clear() {
    this._datas.length = 0;
  }
  *[Symbol.iterator]() {// 遍历效果
    for (const item of this._datas) {
      yield item;
    }
  }
  forEach(callback) {
    for (const item of this._datas) {
      callback(item, item, this);
    }
  }
  /**
     * 判断两个数据是否相等
     * @param {*} data1 
     * @param {*} data2 
     */
  isEqual(data1, data2) {
    if (data1 === 0 && data2 === 0) {
      return true;
    }
    return Object.is(data1, data2);
  }
}
class mySet {
    constructor(optionsArr = []) {
        if (typeof iterator[Symbol.iterator] !== "function") {
            throw new TypeError(`你提供的${iterator}不是一个可迭代的对象`)
        }
        this.list = {}
        this.size = optionsArr.length
        optionsArr.forEach(val => {
            this.list[val] = val
        })
    }
    add(val) {
        if (!this.list[val]) {
            this.list[val] = val
            this.size++
            return true
        }
        return false
    }
    has(val) {
        // 判断下是否是对象,如果是对象返回false
        if (val !== null && typeof val === 'object') return false
        return this.list.hasOwnProperty(val)
    }

    delete(val) {
        if (this.list[val]) {
            delete this.list[val]
            this.size--
            return true
        }
        return false
    }
    clear() {
        this.list = {}
        this.size = 0
    }
    keys() {
        // 键和值是相等的,以值为主
        return Object.values(this.list)
    }
    values() {
        // 键和值是相等的,以值为主
        return Object.values(this.list)
    }
    entries() {
        // 键和值是相等的,以值为主
        return Object.entries(this.list).map(item => {
            item[0] = item[1]
            return item
        })
    }
    forEach(callback) {
        let keys = this.keys()
        for (let i = 0; i < keys.length; i++) {
            callback(keys[i], keys[i], this)
        }
    }
}