Rumah hujung hadapan web Soal Jawab bahagian hadapan Bagaimana untuk memahami penghias es6

Bagaimana untuk memahami penghias es6

Jan 03, 2023 pm 04:14 PM
es6 Penghias

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.

Bagaimana untuk memahami penghias es6

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{ 
}
Salin selepas log masuk

Tentukan fungsi untuk mendapatkan peralatan AK, iaitu penghias

function strong(target){
    target.AK = true
}
Salin selepas log masuk

Gunakan penghias ini untuk meningkatkan askar

@strong
class soldier{
}
Salin selepas log masuk

Pada masa ini, tentera mempunyai senjata

soldier.AK // true
Salin selepas log masuk

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;
Salin selepas log masuk

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
Salin selepas log masuk

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
Salin selepas log masuk

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;
}
Salin selepas log masuk

Menggunakan baca sahaja untuk menghias kaedah nama kelas

class Person {
  @readonly
  name() { return `${this.first} ${this.last}` }
}
Salin selepas log masuk

sama dengan panggilan berikut

readonly(Person.prototype, &#39;name&#39;, descriptor);
Salin selepas log masuk

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(&#39;evaluated&#39;, id);
    return (target, property, descriptor) =>console.log(&#39;executed&#39;, id);
}

class Example {
    @dec(1)
    @dec(2)
    method(){}
}
// evaluated 1
// evaluated 2
// executed 2
// executed 1
Salin selepas log masuk

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() {
}
Salin selepas log masuk

Peringkat penyusunan , menjadi seperti berikut

var counter;
var add;

@add
function foo() {
}

counter = 0;

add = function () {
  counter++;
};
Salin selepas log masuk

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);
Salin selepas log masuk

Ia menjadi lebih mudah melalui penghias

@connect(mapStateToProps, mapDispatchToProps)
export default class MyReactComponent extends React.Component {}
Salin selepas log masuk

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(&#39;foo&#39;) }
};

@mixins(Foo)
class MyClass {}

let obj = new MyClass();
obj.foo() // "foo"
Salin selepas log masuk

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 &#39;core-decorators&#39;;

class Person {
  @autobind
  getPerson() {
    return this;
  }
}

let person = new Person();
let getPerson = person.getPerson;

getPerson() === person;
// true
Salin selepas log masuk

@readonly

readonly penghias menjadikan sifat atau kaedah tidak boleh ditulis

import { readonly } from &#39;core-decorators&#39;;

class Meal {
  @readonly
  entree = &#39;steak&#39;;
}

var dinner = new Meal();
dinner.entree = &#39;salmon&#39;;
// Cannot assign to read only property &#39;entree&#39; of [object Object]
Salin selepas log masuk

@ tidak digunakan lagi

Penghias yang tidak digunakan atau tidak digunakan lagi memaparkan amaran pada konsol, menunjukkan bahawa kaedah itu akan ditamatkan

import { deprecate } from &#39;core-decorators&#39;;

class Person {
  @deprecate
  facepalm() {}

  @deprecate(&#39;功能废除了&#39;)
  facepalmHard() {}
}

let person = new Person();

person.facepalm();
// DEPRECATION Person#facepalm: This function will be removed in future versions.

person.facepalmHard();
// DEPRECATION Person#facepalmHard: 功能废除了
Salin selepas log masuk

[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!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk membalikkan tatasusunan dalam ES6 Bagaimana untuk membalikkan tatasusunan dalam ES6 Oct 26, 2022 pm 06:19 PM

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() ".

Adakah async untuk es6 atau es7? Adakah async untuk es6 atau es7? Jan 29, 2023 pm 05:36 PM

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".

Mengapakah program mini perlu menukar es6 kepada es5? Mengapakah program mini perlu menukar es6 kepada es5? Nov 21, 2022 pm 06:15 PM

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".

Bagaimana untuk mencari item yang berbeza dalam dua tatasusunan dalam es6 Bagaimana untuk mencari item yang berbeza dalam dua tatasusunan dalam es6 Nov 01, 2022 pm 06:07 PM

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)".

Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam es5 dan es6 Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam es5 dan es6 Jan 16, 2023 pm 05:09 PM

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? Bagaimanakah penghias dan pengurus konteks berfungsi dalam Python? Oct 20, 2023 pm 07:04 PM

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

Ajar anda langkah demi langkah cara menggunakan penghias untuk memanjangkan pemasa Python Ajar anda langkah demi langkah cara menggunakan penghias untuk memanjangkan pemasa Python Apr 13, 2023 pm 08:46 PM

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

Apakah maksud zon mati sementara es6? Apakah maksud zon mati sementara es6? Jan 03, 2023 pm 03:56 PM

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.

See all articles