ESlint ialah alat yang hebat untuk menjadikan kod kami lebih konsisten dan menjimatkan banyak masa pasukan kami. Terdapat banyak pemalam yang mengendalikan kebanyakan kes penggunaan generik, tetapi kadangkala kami mempunyai beberapa keperluan khusus dan membuat peraturan kami sendiri akan mengambil masa terlalu lama.
Untuk kes paling mudah, apabila kita hanya mahu melarang penggunaan fungsi (atau apa-apa lagi sebenarnya), kita boleh memanfaatkan peraturan lalai: sintaks-tiada-terhad.
Memahami Pokok Sintaks Abstrak (AST)
Sebelum menulis pemilih pertama kami, kami perlu memahami sistem asas. AST hanyalah perwakilan program dalam bentuk objek bersarang (oleh itu "Pokok" dalam AST), dicipta oleh "penghuraikan". Ia sangat fleksibel kerana ia boleh dibaca dengan mudah, disoal dan dimanipulasi. Alternatifnya ialah menggunakan ungkapan biasa, tetapi itu akan menjadi sangat sukar untuk dibaca dan ditulis. Jadi ia pada asasnya merupakan langkah perantaraan yang membolehkan setiap perkara hebat yang dilakukan oleh IDE dengan memahami kod kami.
Untuk memahami cara ia berfungsi, kita boleh bermain dengan AST Explorer, alat berguna yang menunjukkan sedikit kod dan ASTnya secara selari, di mana anda boleh menuding atau mengklik mana-mana bahagian kod untuk menyerlahkan bahagian AST yang sepadan. :
⚠️ Berhati-hati untuk memilih penghurai dengan betul apabila menukar bahasa.
Sebagai contoh, semasa menulis kod Vue, pastikan anda menggunakan vue-eslint-parser dalam kes kami, kerana kami ingin menulis pemilih ESlint. Anda juga boleh memeriksa apa yang dikeluarkan oleh @vue/compiler-dom, tetapi anda tidak akan dapat menanyakan pepohon yang terhasil dengan peraturan ESlint.
Mencipta pemilih
Alat berguna kedua yang kami perlukan ialah dokumentasi pemilih ESLint. Ia menyenaraikan ungkapan yang boleh kami gunakan untuk menanyakan AST, dan mungkin terasa biasa jika anda sudah biasa menggunakan CSS. Ia berdasarkan gelagat "melata" yang sama, dengan pemadanan seperti keturunan, adik beradik, nod dan penapisan atribut, dan sebagainya. Berikut ialah beberapa contoh daripada dokumen:
- Jenis nod AST: ForStatement
- nilai atribut: [attr="foo"]
- atribut bersarang: [attr.level2="foo"]
- medan: FunctionDeclaration > Identifier.id
Jadi, diberikan kod ini:
const time = dayjs();
Ia akan menjana AST berikut menggunakan @typescript-eslint/parser:
Program { body: [ VariableDeclaration { declarations: [ VariableDeclarator { id: Identifier init: CallExpression { callee: Identifier { name: "dayjs" } arguments: [] optional: false } } ] kind: "const" } ] sourceType: "module" }
Dalam kes kami, kami perlu memadankan panggilan fungsi (CallExpression) yang namanya dayjs (Pengecam dengan sifat nama). Kami juga memerlukan pemilih keturunan langsung > untuk memastikan kami tidak memadankan mana-mana panggilan fungsi yang mempunyai pengecam dayjs bersarang di dalamnya. Jadi pemilihnya ialah CallExpression > Pengecam[name="dayjs"].
Contoh
Pemilih fungsi mudah
Inilah pemilih kami untuk menghalang penggunaan dayjs tanpa UTC yang boleh anda cuba secara langsung di Taman Permainan ESLint:
const time = dayjs();
Program { body: [ VariableDeclaration { declarations: [ VariableDeclarator { id: Identifier init: CallExpression { callee: Identifier { name: "dayjs" } arguments: [] optional: false } } ] kind: "const" } ] sourceType: "module" }
Templat Vue dalam
Ini satu lagi contoh yang melarang cara (agak meretas) untuk menetapkan pembolehubah setempat dalam templat dalam templat Vue (perhatikan bahawa peraturan itu diawali dengan vue/ kerana ia memerlukan pakej eslint-plugin-vue):
'no-restricted-syntax': [ 'error', { selector: 'CallExpression > Identifier[name="dayjs"]', message: 'Always use dayjs.utc() instead of dayjs() to avoid timezone issues', }, ]
const foo = dayjs(); // ^^^^^ Invalid const bar = dayjs.utc();
Dengan cara ini, anda boleh membaca lebih lanjut di sini tentang helah aneh ini yang menyebabkan kami mengalami beberapa isu kereaktifan pada masa lalu, jadi kami memutuskan untuk melarangnya sama sekali.
Menggunakan regex
Ini adalah contoh terakhir, di mana kami mempunyai kes di mana kami perlu melarang penggunaan set terjemahan tertentu, jadi kami terpaksa mencari fungsi t (atau sebarang variasi) yang mempunyai hujah pertama bermula dengan eksport. :
'vue/no-restricted-syntax': [ 'error', { selector: 'VAttribute > VExpressionContainer > AssignmentExpression', message: 'Do not assign values in templates as it will not be reactive', }, ],
<template> <div :set="(foo = 'bar')">{{ foo }}</div> <!-- Outputs <div>bar</div> --> <!-- ^^^^^^^^^^ Invalid --> </template>
Kesimpulan
Jika anda sukar untuk menghasilkan pemilih yang betul, anda boleh meminta bantuan ChatGPT! Ia juga pandai menerangkan pemilih:
Juga jika anda perlu mengehadkan import sahaja, lebih mudah untuk menggunakan peraturan import tanpa had:
'no-restricted-syntax': [ 'error', { selector: 'CallExpression[callee.name=/^(t|tc|tf|te|d|n)$/][arguments.0.value=/^exports./]', message: 'Do not assign values in templates as it will not be reactive', }, ],
Penyelesaian ini berfungsi dengan baik dalam situasi paling mudah, tetapi ia tidak membenarkan anda mencadangkan autofix. Untuk penyelesaian yang lebih lengkap, peraturan tersuai hendaklah dibuat.
Terima kasih kepada peraturan tersebut, kami menjimatkan masa dengan tidak mengulangi kesilapan yang sama dua kali!
Atas ialah kandungan terperinci Mengehadkan beberapa sintaks dengan ESLint. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kedua -dua pilihan Python dan JavaScript dalam persekitaran pembangunan adalah penting. 1) Persekitaran pembangunan Python termasuk Pycharm, Jupyternotebook dan Anaconda, yang sesuai untuk sains data dan prototaip cepat. 2) Persekitaran pembangunan JavaScript termasuk node.js, vscode dan webpack, yang sesuai untuk pembangunan front-end dan back-end. Memilih alat yang betul mengikut keperluan projek dapat meningkatkan kecekapan pembangunan dan kadar kejayaan projek.

Ya, teras enjin JavaScript ditulis dalam C. 1) Bahasa C menyediakan prestasi yang efisien dan kawalan asas, yang sesuai untuk pembangunan enjin JavaScript. 2) Mengambil enjin V8 sebagai contoh, terasnya ditulis dalam C, menggabungkan kecekapan dan ciri-ciri berorientasikan objek C. 3) Prinsip kerja enjin JavaScript termasuk parsing, penyusun dan pelaksanaan, dan bahasa C memainkan peranan penting dalam proses ini.

JavaScript adalah di tengah -tengah laman web moden kerana ia meningkatkan interaktiviti dan dinamik laman web. 1) Ia membolehkan untuk menukar kandungan tanpa menyegarkan halaman, 2) memanipulasi laman web melalui Domapi, 3) menyokong kesan interaktif kompleks seperti animasi dan drag-and-drop, 4) mengoptimumkan prestasi dan amalan terbaik untuk meningkatkan pengalaman pengguna.

C dan JavaScript mencapai interoperabilitas melalui webassembly. 1) Kod C disusun ke dalam modul WebAssembly dan diperkenalkan ke dalam persekitaran JavaScript untuk meningkatkan kuasa pengkomputeran. 2) Dalam pembangunan permainan, C mengendalikan enjin fizik dan rendering grafik, dan JavaScript bertanggungjawab untuk logik permainan dan antara muka pengguna.

JavaScript digunakan secara meluas di laman web, aplikasi mudah alih, aplikasi desktop dan pengaturcaraan sisi pelayan. 1) Dalam pembangunan laman web, JavaScript mengendalikan DOM bersama -sama dengan HTML dan CSS untuk mencapai kesan dinamik dan menyokong rangka kerja seperti JQuery dan React. 2) Melalui reaktnatif dan ionik, JavaScript digunakan untuk membangunkan aplikasi mudah alih rentas platform. 3) Rangka kerja elektron membolehkan JavaScript membina aplikasi desktop. 4) Node.js membolehkan JavaScript berjalan di sisi pelayan dan menyokong permintaan serentak yang tinggi.

Python lebih sesuai untuk sains data dan automasi, manakala JavaScript lebih sesuai untuk pembangunan front-end dan penuh. 1. Python berfungsi dengan baik dalam sains data dan pembelajaran mesin, menggunakan perpustakaan seperti numpy dan panda untuk pemprosesan data dan pemodelan. 2. Python adalah ringkas dan cekap dalam automasi dan skrip. 3. JavaScript sangat diperlukan dalam pembangunan front-end dan digunakan untuk membina laman web dinamik dan aplikasi satu halaman. 4. JavaScript memainkan peranan dalam pembangunan back-end melalui Node.js dan menyokong pembangunan stack penuh.

C dan C memainkan peranan penting dalam enjin JavaScript, terutamanya digunakan untuk melaksanakan jurubahasa dan penyusun JIT. 1) C digunakan untuk menghuraikan kod sumber JavaScript dan menghasilkan pokok sintaks abstrak. 2) C bertanggungjawab untuk menjana dan melaksanakan bytecode. 3) C melaksanakan pengkompil JIT, mengoptimumkan dan menyusun kod hot-spot semasa runtime, dan dengan ketara meningkatkan kecekapan pelaksanaan JavaScript.

Aplikasi JavaScript di dunia nyata termasuk pembangunan depan dan back-end. 1) Memaparkan aplikasi front-end dengan membina aplikasi senarai TODO, yang melibatkan operasi DOM dan pemprosesan acara. 2) Membina Restfulapi melalui Node.js dan menyatakan untuk menunjukkan aplikasi back-end.


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

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft
