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

Bagaimana untuk memahami penghias es6

青灯夜游
青灯夜游asal
2023-01-03 16:14:142244semak imbas

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{ 
}

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!

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