Apakah kegunaan set es6?

青灯夜游
青灯夜游asal
2022-10-24 17:55:551950semak imbas

Set ialah struktur data yang digunakan untuk menyimpan data yang dipesan dalam objek boleh lelar ini dialih keluar, jadi ia boleh digunakan untuk mengalih keluar elemen pendua dan menghalang "Array.from(new Set(arr))" atau "[...new Set(arr)]".

Apakah kegunaan set es6?

Persekitaran pengendalian tutorial ini: sistem Windows 7, ECMAScript versi 6, komputer Dell G3.

1. Penggunaan asas

Set ialah struktur data baharu yang disediakan oleh ES6 Ia digunakan untuk menyimpan data tersusun seperti tatasusunan tiada keupayaan akses rawak, iaitu, anda tidak boleh mendapatkan elemen tertentu melalui pengindeksan seperti tatasusunan. Selain itu, perkara yang paling penting ialah elemen dalam Set adalah unik dan elemen yang sama tidak dibenarkan disimpan!

Set ialah pembina yang digunakan untuk membuat instantiate contoh:

let set = new Set()
set.add(1)//往set集合中添加元素1

Jika tidak, Set() boleh menerima objek lelaran sebagai parameter, sebagai data permulaan Instance, tetapi kandungan yang sama dalam objek boleh lelar ini akan dialih keluar Walau bagaimanapun, ini juga merupakan kaedah penyahduplikasian tatasusunan.

let set = new Set([1,2,2,1,4,3,5])
console.log(set)//Set(5) {1, 2, 4, 3, 5}

Keunikan elemen boleh digunakan untuk menghapuskan pendua dalam tatasusunan:

//方法一:
Array.from(new Set(arr)) //arr是待去重的数组

//方法二:
[...new Set(arr)]

Betapa hebatnya, menggunakan ciri ini juga boleh mencapai rentetan rentetan penyahduplikasian aksara.

[...new Set(str)].join('')

Walau bagaimanapun, semua perkara di atas dicapai melalui keunikan elemen jenis Set, jadi bagaimanakah Set secara dalaman menentukan sama ada sesuatu elemen itu unik? Ia menggunakan algoritma Same-value-zero equality secara dalaman, yang kira-kira sama dengan pengendali kongruen, kecuali algoritma ini menganggap NaN sama dengan NaN .

2 Atribut dan kaedah Instance

Atribut Instance

Pada Set.prototype, atribut mewakili bilangan unsur. size

let set = new Set([1,2,2,1,4,3,5])
console.log(set.size)//5

Kaedah tikar

Kaedah tika boleh dibahagikan kepada dua kategori: kaedah operasi dan kaedah traversal. Set

1. Kaedah operasi

  • - Tambahkan nilai pada penghujung Set.prototype.add(value) dan kembalikan Set itu sendiri. Set
  • - Padamkan nilai dan kembalikan nilai Boolean yang menunjukkan sama ada pemadaman berjaya. Set.prototype.delete(value)
  • - Mengembalikan nilai Boolean yang menunjukkan sama ada nilai itu ialah elemen Set.prototype.has(value). Set
  • - Kosongkan semua ahli, tiada nilai pulangan. Set.prototype.clear()
Perlu dinyatakan bahawa pengembalian kaedah

adalah add() itu sendiri, jadi anda sepatutnya boleh memikirkan panggilan berantai: Set

let set = new Set()
set.add(1).add(2).add(3)

2. Kaedah traversal

  • - penyeberang yang mengembalikan nama utama Set.prototype.keys()
  • - penyeberang yang mengembalikan nilai kunci Set.prototype.values()
  • —— Mengembalikan penyeberang pasangan nilai kunci Set.prototype.entries()
  • —— Gunakan fungsi panggil balik untuk melintasi elemen Set.prototype.forEach()
Memandangkan struktur

tidak mempunyai nama kunci , hanya nilai kunci (atau Nama kunci dan nilai kunci adalah nilai yang sama), jadi kaedah Set berkelakuan sama dengan kaedah keys. values

3. WeakSet

ialah versi dinaik taraf WeakSet, dengan dua perbezaan utama: Set

  • Hanya jenis rujukan boleh disimpan, bukan data jenis asas. Jenis rujukan dalam WeakSet
  • semuanya adalah rujukan yang lemah. WeakSet
Pertama sekali, perkara pertama mudah difahami, iaitu jenis data asas tidak boleh disimpan:

const ws = new WeakSet()
ws.add(1)//报错,Invalid value used in weak set
Kemudian titik kedua, objek dalam

semuanya adalah rujukan yang lemah. Ini bermakna mekanisme kutipan sampah tidak akan mempertimbangkan rujukan WeakSet kepada objek Setelah kiraan rujukan luaran mencapai 0, ia akan menunggu untuk diproses oleh mekanisme kutipan sampah. Oleh itu, WeakSet sesuai untuk menyimpan sementara sekumpulan objek. WeakSet

Disebabkan ciri ini, ahli dalam

tidak sesuai untuk rujukan, kerana ia mungkin akan dibersihkan pada bila-bila masa, namun, WeakSet menetapkan bahawa ia tidak boleh dilalui. Kaedah dalam ES6

pada asasnya sama dengan WeakSet yang dinyatakan di atas, tetapi ia tidak mempunyai atribut Set dan tiada kaedah traverser. size

[Cadangan berkaitan:

tutorial video javascript, Video pengaturcaraan]

Atas ialah kandungan terperinci Apakah kegunaan set es6?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn