Rumah hujung hadapan web Soal Jawab bahagian hadapan nodejs melaksanakan pemilihan folder

nodejs melaksanakan pemilihan folder

May 28, 2023 pm 01:47 PM

Node.js ialah bahasa pengaturcaraan JavaScript bahagian belakang yang popular yang digunakan secara meluas untuk membina aplikasi web, API, alatan baris arahan, dsb. Dalam Node.js, kadangkala anda perlu membenarkan pengguna memilih folder untuk membaca, menulis dan mengubah suai dalam program. Artikel ini akan memperkenalkan cara menggunakan Node.js untuk memilih folder.

1. Gunakan Node.js asli untuk memilih folder

Node.js menyediakan modul fs untuk mengendalikan sistem fail. Dalam modul fs, terdapat kaedah yang dipanggil readdir, yang boleh membaca semua fail dan subdirektori dalam direktori. Berikut ialah contoh kod yang menggunakan Node.js asli untuk memilih folder:

const fs = require('fs');
const path = require('path');

let dir = process.argv[2] || '.';

fs.readdir(dir, (err, files) => {
  if (err) throw err;
  console.log('请选择一个文件夹:');
  files.forEach(file => {
    let filePath = path.join(dir, file);
    fs.stat(filePath, (err, stats) => {
      if (err) throw err;
      if (stats.isDirectory()) {
        console.log(`[${file}]`);
      } else {
        console.log(file);
      }
    });
  });
  process.stdin.resume();
  process.stdin.setEncoding('utf8');
  process.stdin.on('data', data => {
    data = data.trim();
    let filePath = path.join(dir, data);
    fs.stat(filePath, (err, stats) => {
      if (err) throw err;
      if (stats.isDirectory()) {
        process.stdin.pause();
        console.log(`已选择[${data}]文件夹!`);
      } else {
        console.log(`${data}不是一个有效的文件夹!`);
      }
    });
  });
});
Salin selepas log masuk

Kod pertama kali menggunakan kaedah fs.readdir untuk membaca folder yang ditentukan pengguna, dan kemudian menggunakan kaedah fs.stat untuk tentukan sama ada setiap fail Bukan folder. Akhir sekali, process.stdin digunakan untuk mendapatkan input pengguna Jika input pengguna ialah folder, ia bermakna pengguna memilih folder.

2. Gunakan modul pihak ketiga untuk memilih folder

Selain menggunakan Node.js asli, anda juga boleh menggunakan modul pihak ketiga untuk memilih folder. Berikut ialah dua modul pihak ketiga biasa untuk memilih folder.

  1. inquirer

inquirer ialah perpustakaan antara muka pengguna baris arahan interaktif yang berkuasa yang boleh membuat pilihan interaktif pada baris arahan seperti membangunkan borang web. Berikut ialah contoh kod yang menggunakan penyiasat untuk memilih folder:

const inquirer = require('inquirer');
const fs = require('fs');
const path = require('path');

let dirs = fs
  .readdirSync('.')
  .filter(file => {
    return fs.statSync(file).isDirectory();
  })
  .map(dir => {
    return { name: `[${dir}]`, value: dir };
  });

inquirer
  .prompt([
    {
      type: 'list',
      name: 'dir',
      message: '请选择一个文件夹:',
      choices: dirs,
    },
  ])
  .then(answer => {
    console.log(`已选择[${answer.dir}]文件夹!`);
  });
Salin selepas log masuk

Kod ini menggunakan kaedah fs.readdirSync untuk membaca semua folder dalam direktori semasa dan menggunakan kaedah penapis untuk menapis semua folder. Kemudian setiap folder dikapsulkan ke dalam objek melalui kaedah peta, supaya nama folder boleh dipaparkan dalam senarai pilihan penyiasat. Akhir sekali, gunakan kaedah inquirer.prompt untuk memaparkan senarai pilihan untuk membenarkan pengguna memilih folder dan gunakan answer.dir untuk mendapatkan nama folder yang dipilih oleh pengguna.

  1. file-tree-select

file-tree-select ialah pemalam pemilih fail yang dibina pada inquirer dan node-file-tree. Ia boleh memaparkan pepohon fail dalam direktori semasa pada baris arahan, dan pengguna boleh memilih folder melalui anak panah atas dan bawah serta bar ruang papan kekunci. Berikut ialah contoh kod yang menggunakan fail-tree-select untuk memilih folder:

const fileTreeSelect = require('file-tree-select');
const path = require('path');

let dir = process.argv[2] || '.';
let absDir = path.resolve(dir);

fileTreeSelect(absDir, { hideFiles: true }).then(result => {
  console.log(`已选择[${result}]文件夹!`);
});
Salin selepas log masuk

Kod pertama kali menggunakan kaedah path.resolve untuk menyelesaikan nama folder yang dimasukkan oleh pengguna ke dalam laluan mutlak. Kemudian gunakan kaedah fileTreeSelect untuk memaparkan pepohon fail dalam direktori semasa, dan pengguna boleh menggunakan operasi papan kekunci untuk memilih folder. Akhir sekali, gunakan kaedah .then untuk mendapatkan laluan folder yang dipilih oleh pengguna.

3. Ringkasan

Memilih folder ialah operasi biasa dalam Node.js. Artikel ini memperkenalkan tiga cara untuk memilih folder menggunakan Node.js asli, inquirer dan file-tree-select. Untuk projek kecil, menggunakan Node.js asli boleh memenuhi keperluan untuk projek besar, menggunakan modul pihak ketiga boleh meningkatkan kecekapan pembangunan dan kualiti kod.

Atas ialah kandungan terperinci nodejs melaksanakan pemilihan folder. 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!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

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)

Topik panas

Tutorial Java
1673
14
Tutorial PHP
1278
29
Tutorial C#
1257
24
Ekosistem React: Perpustakaan, Alat, dan Amalan Terbaik Ekosistem React: Perpustakaan, Alat, dan Amalan Terbaik Apr 18, 2025 am 12:23 AM

Ekosistem React termasuk perpustakaan pengurusan negeri (seperti redux), perpustakaan penghalaan (seperti reactrouter), perpustakaan komponen UI (seperti bahan-UI), alat ujian (seperti jest), dan alat bangunan (seperti webpack). Alat ini bekerjasama untuk membantu pemaju membangun dan mengekalkan aplikasi dengan cekap, meningkatkan kualiti kod dan kecekapan pembangunan.

React: Kekuatan perpustakaan JavaScript untuk pembangunan web React: Kekuatan perpustakaan JavaScript untuk pembangunan web Apr 18, 2025 am 12:25 AM

React adalah perpustakaan JavaScript yang dibangunkan oleh Meta untuk membina antara muka pengguna, dengan terasnya menjadi pembangunan komponen dan teknologi DOM maya. 1. Komponen dan Pengurusan Negeri: React menguruskan keadaan melalui komponen (fungsi atau kelas) dan cangkuk (seperti UseState), meningkatkan kebolehgunaan semula kod dan penyelenggaraan. 2. DOM maya dan pengoptimuman prestasi: Melalui DOM maya, bereaksi dengan cekap mengemas kini DOM sebenar untuk meningkatkan prestasi. 3. Kitaran Hidup dan Cangkuk: Cangkuk (seperti Useeffect) membolehkan komponen fungsi menguruskan kitaran hayat dan melakukan operasi kesan sampingan. 4. Contoh Penggunaan: Dari Komponen Helloworld Asas ke Pengurusan Negeri Global Lanjutan (USEContext dan

Masa Depan React: Trend dan Inovasi dalam Pembangunan Web Masa Depan React: Trend dan Inovasi dalam Pembangunan Web Apr 19, 2025 am 12:22 AM

Masa depan React akan memberi tumpuan kepada pembangunan komponen utama, pengoptimuman prestasi dan integrasi yang mendalam dengan susunan teknologi lain. 1) React akan memudahkan penciptaan dan pengurusan komponen dan mempromosikan perkembangan komponen utama. 2) Pengoptimuman prestasi akan menjadi tumpuan, terutamanya dalam aplikasi besar. 3) React akan disepadukan dengan teknologi seperti GraphQL dan TypeScript untuk meningkatkan pengalaman pembangunan.

Pembangunan Frontend dengan React: Kelebihan dan Teknik Pembangunan Frontend dengan React: Kelebihan dan Teknik Apr 17, 2025 am 12:25 AM

Kelebihan React adalah fleksibiliti dan kecekapannya, yang dicerminkan dalam: 1) Reka bentuk berasaskan komponen meningkatkan kebolehgunaan semula kod; 2) Teknologi DOM Maya mengoptimumkan prestasi, terutamanya apabila mengendalikan banyak kemas kini data; 3) Ekosistem yang kaya menyediakan sejumlah besar perpustakaan dan alat pihak ketiga. Dengan memahami bagaimana React Works dan menggunakan contoh, anda boleh menguasai konsep terasnya dan amalan terbaik untuk membina antara muka pengguna yang cekap dan boleh dipelihara.

Pembangunan React dan Frontend: Gambaran keseluruhan yang komprehensif Pembangunan React dan Frontend: Gambaran keseluruhan yang komprehensif Apr 18, 2025 am 12:23 AM

React adalah perpustakaan JavaScript yang dibangunkan oleh Facebook untuk membina antara muka pengguna. 1. Ia mengamalkan teknologi DOM komponen dan maya untuk meningkatkan kecekapan dan prestasi pembangunan UI. 2. Konsep teras React termasuk komponenisasi, pengurusan negeri (seperti useState dan useeffect) dan prinsip kerja dom maya. 3. 4. Kesilapan umum seperti melupakan untuk menambah atribut utama atau kemas kini status yang salah boleh didebitkan melalui ReactDevTools dan log. 5. Pengoptimuman prestasi dan amalan terbaik termasuk menggunakan react.memo, segmentasi kod dan menyimpan kod yang boleh dibaca dan mengekalkan kebolehpercayaan

Memahami Fungsi Utama React: Perspektif Frontend Memahami Fungsi Utama React: Perspektif Frontend Apr 18, 2025 am 12:15 AM

Fungsi utama React termasuk pemikiran komponen, pengurusan negeri dan dom maya. 1) Idea komponenisasi membolehkan pemisahan UI menjadi bahagian yang boleh diguna semula untuk meningkatkan kebolehbacaan kod dan kebolehkerjaan. 2) Pengurusan Negeri menguruskan data dinamik melalui negeri dan prop, dan perubahan mencetuskan kemas kini UI. 3) Prestasi Pengoptimuman DOM Maya, kemas kini UI melalui pengiraan operasi minimum Replika DOM dalam ingatan.

Kekuatan React dalam HTML: Pembangunan Web Moden Kekuatan React dalam HTML: Pembangunan Web Moden Apr 18, 2025 am 12:22 AM

Penggunaan React dalam HTML meningkatkan kecekapan dan fleksibiliti pembangunan web melalui komponen dan DOM maya. 1) Idea komponen reaksi memecah UI ke dalam unit yang boleh diguna semula untuk memudahkan pengurusan. 2) Prestasi pengoptimuman DOM maya, meminimumkan operasi DOM melalui algoritma yang berbeza. 3) Sintaks JSX membolehkan penulisan HTML dalam JavaScript untuk meningkatkan kecekapan pembangunan. 4) Gunakan cangkuk UseState untuk menguruskan keadaan dan merealisasikan kemas kini kandungan dinamik. 5) Strategi pengoptimuman termasuk menggunakan react.memo dan usecallback untuk mengurangkan rendering yang tidak perlu.

React vs Rangka Kerja Lain: Membandingkan dan Berbeza Pilihan React vs Rangka Kerja Lain: Membandingkan dan Berbeza Pilihan Apr 17, 2025 am 12:23 AM

React adalah perpustakaan JavaScript untuk membina antara muka pengguna, sesuai untuk aplikasi besar dan kompleks. 1. Inti React adalah komponen dan DOM maya, yang meningkatkan prestasi rendering UI. 2. Berbanding dengan Vue, React lebih fleksibel tetapi mempunyai lengkung pembelajaran yang curam, yang sesuai untuk projek besar. 3. Berbanding dengan sudut, bertindak balas lebih ringan, bergantung kepada ekologi komuniti, dan sesuai untuk projek yang memerlukan fleksibiliti.

See all articles