Rumah >hujung hadapan web >tutorial js >Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

青灯夜游
青灯夜游ke hadapan
2023-01-31 20:34:182783semak imbas

Bagaimana untuk menukar sumber dalam nod? Artikel berikut akan menunjukkan kepada anda cara membuat alat sumber pensuisan nod Saya harap ia akan membantu anda!

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Hei, hey, sudah tiba masanya untuk menulis tentang roda sekali lagi. Mengapa anda mahu menulis ini?

Sepatutnya muat turun sumber npm sendiri sangat perlahan

Sudah ada alat nrm Ia juga digunakan untuk menukar sumber, seperti sumber tabao, sumber Tencent, dan semasa memuat turun pakej bergantung Jika ia boleh dipercepatkan, terdapat begitu banyak sumber yang nrm boleh membantu kami mengurus dan menukar pada bila-bila masa.

Rakan pertama memasangnyanrmIa sangat menyusahkan dan perlu dipasang menggunakan kod sumber

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Syarikat rakan kedua mempunyai banyak pelayan peribadi dan saya saya terlalu malas untuk melakukannya secara manual Tukar

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Jadi kami ingin menulis alat kecil untuk menukar sumber npm dengan mudah [Cadangan tutorial berkaitan: tutorial video nodejs ]

Idea 1, panggil arahan untuk menetapkan sumber

npm config set registry  源地址

Idea 2 menggunakan arahan pandangan untuk mendapatkan alamat sumber

npm config get registry

Ia terutamanya ini dua langkah

Pelaksanaan kod

commander

commander ialah modul nodejs yang boleh menghuraikan arahan yang kami masukkan dan biasanya digunakan dalam pelbagai perancah seperti vue vite dsb.

Contohnya, xxx -V Lihat versi xxx use Laksanakan skrip xxx -h Lihat bantuan dsb. boleh dilaksanakan menggunakan commander

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

inquirer

inquirer juga merupakan modul nodejs, sering digunakan untuk interaksi arahan, seperti vue's cli, vite, dsb., bertindak balas perancah, dsb.

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Sebagai contoh, pilihan ini , serta kotak input, berbilang pilihan, dsb.

registries.json

Letakkan beberapa sumber awal dalam fail ini. Ping yang dicuri dari github nrm telah ditambahkan oleh saya sendiri

{
    "npm": {
        "home": "https://www.npmjs.org",
        "registry": "https://registry.npmjs.org/",
        "ping": "https://registry.npmjs.org"
    },
    "yarn": {
        "home": "https://yarnpkg.com",
        "registry": "https://registry.yarnpkg.com/",
        "ping": "https://registry.yarnpkg.com"
    },
    "tencent": {
        "home": "https://mirrors.cloud.tencent.com/npm/",
        "registry": "https://mirrors.cloud.tencent.com/npm/",
        "ping": "https://mirrors.cloud.tencent.com/npm"
    },
    "cnpm": {
        "home": "https://cnpmjs.org",
        "registry": "https://r.cnpmjs.org/",
        "ping": "https://r.cnpmjs.org"
    },
    "taobao": {
        "home": "https://npmmirror.com",
        "registry": "https://registry.npmmirror.com/",
        "ping": "https://registry.npmmirror.com"
    },
    "npmMirror": {
        "home": "https://skimdb.npmjs.com/",
        "registry": "https://skimdb.npmjs.com/registry/",
        "ping": "https://skimdb.npmjs.com/registry"
    }
}
#!/usr/bin/env node

const { program } = require('commander')
const PKG = require('../package.json') //引入package json
const registries = require('../registries.json'); //引入初始源
const inquirer = require('inquirer');
const { exec, execSync } = require('child_process') //子线程用于执行shell命令
const ping = require('node-http-ping') //ping网址的一个库
const fs = require('fs')
const chalk = require("chalk"); //console 变颜色的一个库
const path = require('path')
program.version(PKG.version) //设置版本默认命令 -V --version

//读取源地址方便设置*
const getOrigin = async () => {
    return await execSync('npm get registry', { encoding: "utf-8" })
}

//列出所有的源,如果当前有在使用前面加上*
program.command('ls').description('查看镜像').action(async () => {

    const res = await getOrigin()

    const keys = Object.keys(registries)

    const message = []

    //填充横线算法npm------  yarn------
    const max = Math.max(...keys.map(v => v.length)) + 3
    keys.forEach(k => {

        const newK = registries[k].registry == res.trim() ? ('* ' + k) : ('  ' + k)
        const Arr = new Array(...newK)
        Arr.length = max;
        const prefix = Array.from(Arr).map(v => v ? v : '-').join('')

        message.push(prefix + '  ' + registries[k].registry)
    })
    console.log(message.join('\n'))
})

//切换源
program.command('use').description('请选择镜像').action(() => {
    inquirer.prompt([
        {
            type: "list",
            name: "sel",
            message: "请选择镜像",
            choices: Object.keys(registries)
        }
    ]).then(result => {

        const reg = registries[result.sel].registry

        exec(`npm config set registry ${reg}`, null, (err, stdout, stderr) => {

            if (err) {
                console.error('切换错误', err)
            } else {
                console.log('切换成功')
            }
        })
    })
})



//获取当前源
program.command('current').description('查看当前源').action(async () => {
    const reg = await getOrigin()
    const v = Object.keys(registries).find(k => {
        if (registries[k].registry === reg.trim()) {
            return k;
        }
    })
    console.log(chalk.blue('当前源:', v))
})

//ping 源
program.command('ping').description('测试镜像地址速度').action(() => {
    inquirer.prompt([
        {
            type: "list",
            name: "sel",
            message: "请选择镜像",
            choices: Object.keys(registries)
        }
    ]).then(result => {

        const url = registries[result.sel].ping.trim()

        ping(url).then(time => console.log(chalk.blue(`响应时长: ${time}ms`)))
            .catch(() => console.log(chalk.red('GG')))

    })
})

//添加源 读写registries.json 文件实现
program.command('add').description('自定义镜像').action(() => {
    inquirer.prompt([
        {
            type: "input",
            name: "name",
            message: "请输入镜像名称",
            validate(answer) {
                const keys = Object.keys(registries)
                if (keys.includes(answer)) {
                    return `不能起名${answer}跟保留字冲突`
                }
                if (!answer) {
                    return '名称不能为空'
                }
                return true
            }
        },
        {
            type: "input",
            name: "url",
            message: "请输入镜像地址",
            validate(answer) {
                if (!answer) {
                    return `url不能为空`
                }
                return true
            }       
        }
    ]).then(result => {

        const del = (url) => {
            const arr = url.split('')
            //本来想用at 16 以下不支持
            return arr[arr.length - 1] == '/' ? (arr.pop() && arr.join('')) : arr.join('')
        }

        registries[result.name] = {
            home: result.url.trim(),
            registry: result.url.trim(),
            ping: del(result.url.trim()), //去掉末尾/ 不然无法ping
        }
        fs.writeFileSync(path.join(__dirname, '../registries.json'), JSON.stringify(registries, null, 4))
        console.log(chalk.blue('添加完成'))
    })
})



program.parse(process.argv)

Cara menggunakannya

npm i xmzs -g

Selepas pemasangan, akan ada arahan mmp Mengapa tidak dipanggil xmzs? 🎜>mmp

mmp ls

Tukar sumber nrm adalah input, saya mempunyai kotak pilihan di sini untuk menjadikannya lebih mudah

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

mmp use

Lihat sumber semasa

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

mmp current

Ujian kelajuan

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

mmp ping

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Sumber tersuai

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

map add

mmp ls view

Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Untuk lebih banyak pengetahuan berkaitan nod, sila lawati:

tutorial nodejs

! Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod

Atas ialah kandungan terperinci Membawa anda langkah demi langkah untuk membangunkan alat sumber pensuisan nod. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:juejin.cn. Jika ada pelanggaran, sila hubungi admin@php.cn Padam