Bagaimana untuk memahami penghias es6
Dalam es6, corak penghias ialah teori reka bentuk yang memanjangkan fungsi objek secara dinamik tanpa mengubah kelas asal dan menggunakan pewarisan adalah fungsi biasa, digunakan untuk atribut Kelas lanjutan dan kelas kaedah. Kelebihan menggunakan penghias: 1. Kod menjadi lebih mudah dibaca, dan penamaan penghias adalah setara dengan ulasan 2. Fungsi asal boleh dikembangkan tanpa mengubah kod asal.
Persekitaran pengendalian tutorial ini: sistem Windows 7, ECMAScript versi 6, komputer Dell G3.
Bagaimana untuk memahami Penghias dalam ES6?
Penghias, penghias, dari namanya dengan mudah boleh mengingatkan kita tentang corak penghias
Ringkasnya, corak penghias ialah kaedah yang tidak mengubah Kelas asal dan teori reka bentuk memanjangkan fungsi objek secara dinamik menggunakan pewarisan.
Hal yang sama berlaku untuk fungsi Penghias dalam ES6 Intipatinya bukanlah struktur tinggi, ia adalah fungsi biasa yang digunakan untuk melanjutkan atribut kelas dan kaedah kelas
Seorang askar ditakrifkan di sini. Dia tidak mempunyai peralatan
class soldier{ }
Tentukan fungsi untuk mendapatkan peralatan AK, iaitu penghias
function strong(target){ target.AK = true }
Gunakan penghias ini untuk meningkatkan askar
@strong class soldier{ }
Pada masa ini, tentera mempunyai senjata
soldier.AK // true
Walaupun kod di atas mudah, anda boleh melihat dengan jelas dua kelebihan menggunakan Decorator:
Kod tersebut mempunyai menjadi lebih mudah dibaca dan penamaan penghias adalah bersamaan dengan ulasan
Melanjutkan fungsi asal tanpa menukar kod asal
Penggunaan penghias
Objek yang diubah suai doktor ialah dua jenis berikut:
Hiasan kelas
- <>
Hiasan atribut kelas
Hiasan kelas
Apabila menghias kelas itu sendiri, Boleh menerima satu parameter, iaitu kelas itu sendiri
Uraikan tingkah laku penghias, dan semua orang boleh mempunyai pemahaman yang lebih mendalam
@decorator class A {} // 等同于 class A {} A = decorator(A) || A;
Yang berikut @testable
ialah penghias, dan sasarannya ialah pas Kelas yang diimport, MyTestableClass, melaksanakan penambahan atribut statik kepada kelas
@testable class MyTestableClass { // ... } function testable(target) { target.isTestable = true; } MyTestableClass.isTestable // true
Jika anda ingin menghantar parameter, anda boleh merangkum lapisan fungsi di luar penghias
function testable(isTestable) { return function(target) { target.isTestable = isTestable; } } @testable(true) class MyTestableClass {} MyTestableClass.isTestable // true @testable(false) class MyClass {} MyClass.isTestable // false
Hiasan atribut kelas
Apabila menghias atribut kelas, ia boleh menerima tiga parameter:
Objek prototaip kelas
Nama atribut yang perlu dihias
Objek perihalan nama atribut yang dihias
Mula-mula tentukan penghias baca sahaja
function readonly(target, name, descriptor){ descriptor.writable = false; // 将可写属性设为false return descriptor; }
Menggunakan baca sahaja untuk menghias kaedah nama kelas
class Person { @readonly name() { return `${this.first} ${this.last}` } }
sama dengan panggilan berikut
readonly(Person.prototype, 'name', descriptor);
Jika kaedah mempunyai berbilang penghias, ia seperti bawang , mula-mula masukkan dari luar ke dalam, dan kemudian laksanakan dari dalam ke luar
function dec(id){ console.log('evaluated', id); return (target, property, descriptor) =>console.log('executed', id); } class Example { @dec(1) @dec(2) method(){} } // evaluated 1 // evaluated 2 // executed 2 // executed 1
Penghias luar @dec(1) masuk dahulu, tetapi penghias dalam @dec(2) laksanakan dahulu
Nota
Penghias tidak boleh digunakan untuk menghiasi fungsi kerana terdapat pengisytiharan berubah dalam fungsi
var counter = 0; var add = function () { counter++; }; @add function foo() { }
Peringkat penyusunan , menjadi seperti berikut
var counter; var add; @add function foo() { } counter = 0; add = function () { counter++; };
Niatnya ialah pembilang adalah sama dengan 1 selepas pelaksanaan, tetapi hasil sebenar ialah pembilang itu sama dengan 0
Senario penggunaan penghias
Berdasarkan fungsi berkuasa Penghias, kami boleh memenuhi keperluan pelbagai senario Berikut adalah beberapa:
Apabila menggunakan react-redux, jika ia ditulis dalam perkara berikut. bentuk, kedua-duanya Tak sedap dipandang dan menyusahkan
class MyReactComponent extends React.Component {} export default connect(mapStateToProps, mapDispatchToProps)(MyReactComponent);
Ia menjadi lebih mudah melalui penghias
@connect(mapStateToProps, mapDispatchToProps) export default class MyReactComponent extends React.Component {}
Mixin juga boleh ditulis sebagai penghias, menjadikan penggunaan lebih ringkas
function mixins(...list) { return function (target) { Object.assign(target.prototype, ...list); }; } // 使用 const Foo = { foo() { console.log('foo') } }; @mixins(Foo) class MyClass {} let obj = new MyClass(); obj.foo() // "foo"
Mari kita bincangkan tentang beberapa penghias biasa dalam penghias teras.js
@antobind
Penghias autobind menjadikan objek ini dalam kaedah , mengikat objek asal
import { autobind } from 'core-decorators'; class Person { @autobind getPerson() { return this; } } let person = new Person(); let getPerson = person.getPerson; getPerson() === person; // true
@readonly
readonly penghias menjadikan sifat atau kaedah tidak boleh ditulis
import { readonly } from 'core-decorators'; class Meal { @readonly entree = 'steak'; } var dinner = new Meal(); dinner.entree = 'salmon'; // Cannot assign to read only property 'entree' of [object Object]
@ tidak digunakan lagi
Penghias yang tidak digunakan atau tidak digunakan lagi memaparkan amaran pada konsol, menunjukkan bahawa kaedah itu akan ditamatkan
import { deprecate } from 'core-decorators'; class Person { @deprecate facepalm() {} @deprecate('功能废除了') facepalmHard() {} } let person = new Person(); person.facepalm(); // DEPRECATION Person#facepalm: This function will be removed in future versions. person.facepalmHard(); // DEPRECATION Person#facepalmHard: 功能废除了
[Cadangan berkaitan: tutorial video javascript, bahagian hadapan web 】
Atas ialah kandungan terperinci Bagaimana untuk memahami penghias es6. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Dalam ES6, anda boleh menggunakan kaedah reverse() objek tatasusunan untuk mencapai pembalikan tatasusunan Kaedah ini digunakan untuk membalikkan susunan elemen dalam tatasusunan, meletakkan elemen terakhir dahulu dan elemen pertama terakhir .reverse()". Kaedah reverse() akan mengubah suai tatasusunan asal Jika anda tidak mahu mengubah suainya, anda perlu menggunakannya dengan operator pengembangan "..." dan sintaksnya ialah "[...array].reverse() ".

async ialah es7. async dan await ialah penambahan baharu kepada ES7 dan merupakan penyelesaian untuk operasi asynchronous/wait boleh dikatakan sebagai gula sintaktik untuk modul bersama dan fungsi penjana, menyelesaikan kod tak segerak dengan semantik yang lebih jelas. Seperti namanya, async bermaksud "tak segerak".

Untuk keserasian pelayar. Sebagai spesifikasi baharu untuk JS, ES6 menambah banyak sintaks dan API baharu Walau bagaimanapun, penyemak imbas moden tidak mempunyai sokongan tinggi untuk ciri baharu ES6, jadi kod ES6 perlu ditukar kepada kod ES5. Dalam alat pembangun web WeChat, babel digunakan secara lalai untuk menukar kod sintaks ES6 pembangun kepada kod ES5 yang disokong dengan baik oleh ketiga-tiga terminal, membantu pembangun menyelesaikan masalah pembangunan yang disebabkan oleh persekitaran yang berbeza hanya dalam projek Hanya konfigurasi dan semak Pilihan "ES6 hingga ES5".

Langkah-langkah: 1. Tukar dua tatasusunan untuk menetapkan jenis masing-masing, dengan sintaks "newA=new Set(a);newB=new Set(b);" 2. Gunakan has() dan filter() untuk mencari set perbezaan , dengan sintaks " new Set([...newA].filter(x =>!newB.has(x)))", elemen set perbezaan akan dimasukkan dalam koleksi set dan dikembalikan 3. Gunakan Array. daripada untuk menukar set menjadi Jenis tatasusunan, sintaks "Array.from(collection)".

Dalam es5, anda boleh menggunakan fungsi for dan indexOf() untuk mencapai deduplikasi tatasusunan Sintaks "for(i=0;i<array length;i++){a=newArr.indexOf(arr[i]);if(. a== -1){...}}". Dalam es6, anda boleh menggunakan operator spread, Array.from() dan Set untuk mengalih keluar penduaan anda perlu terlebih dahulu menukar tatasusunan menjadi objek Set untuk mengalih keluar pendua, dan kemudian menggunakan fungsi spread atau Array.from() untuk tukar objek Set kembali kepada kumpulan Just.

Bagaimanakah penghias dan pengurus konteks berfungsi dalam Python? Dalam Python, penghias dan pengurus konteks ialah dua konsep dan ciri yang sangat berguna. Kesemuanya direka untuk memudahkan kod, meningkatkan kebolehbacaan kod dan memudahkan penggunaan semula kod. 1. Penghias Penghias ialah fungsi khas dalam Python yang digunakan untuk mengubah suai kelakuan sesuatu fungsi. Ia membolehkan kami membungkus atau melanjutkan fungsi asal tanpa mengubah suainya. Penghias digunakan secara meluas dalam banyak rangka kerja dan perpustakaan Python, seperti Flask, Dj

Ini adalah artikel ketiga kami untuk mengajar anda langkah demi langkah cara melaksanakan pemasa Python. Dua artikel pertama: mengajar anda langkah demi langkah cara melaksanakan pemasa Python, dan menggunakan pengurus konteks untuk melanjutkan pemasa Python, menjadikan kelas Pemasa kami mudah digunakan, cantik dan praktikal. Tetapi kami tidak berpuas hati dengan ini, masih terdapat kes penggunaan yang boleh memudahkannya lagi. Katakan kita perlu menjejaki masa yang dibelanjakan dalam fungsi tertentu dalam pangkalan kod kita. Dengan pengurus konteks, anda pada asasnya mempunyai dua pilihan berbeza: 1. Gunakan Pemasa setiap kali anda memanggil fungsi: dengan Pemasa("some_name"): do_something() Apabila kita berada dalam

Dalam es6, zon mati sementara ialah ralat sintaks, yang merujuk kepada arahan let dan const yang menjadikan blok membentuk skop tertutup. Dalam blok kod, sebelum pembolehubah diisytiharkan menggunakan perintah let/const, pembolehubah tidak tersedia dan tergolong dalam "zon mati" pembolehubah sebelum pembolehubah diisytiharkan ini secara sintaksis dipanggil "zon mati sementara". ES6 menetapkan bahawa promosi pembolehubah tidak berlaku dalam zon mati sementara dan pernyataan let dan const, terutamanya untuk mengurangkan ralat masa jalan dan menghalang pembolehubah daripada digunakan sebelum ia diisytiharkan, yang mungkin membawa kepada tingkah laku yang tidak dijangka.
