微信小程序转换器(四)—— 异步loader实现 - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

微信小程序转换器(四)—— 异步loader实现

发表时间:2021-1-5

发布人:葵宇科技

浏览次数:43

loader递归调用修改

判断loader返回值是否为promise,是就等待promise完成,得到值,否则直接获取返回值。

async function useLoader(source, loaders = []) {
	//...省略loader过滤阶段,假设loaderList = loaders
    
    const loaderList = loaders

    async function runLoader(source, loaderList) {
        const loader = loaderList.pop()
        let newSource
        if (isPromise(loader)) newSource = await loader(source)
        else newSource = loader(source)
        if (loaderList.length > 0) return runLoader(newSource, loaderList)
        else return newSource

    }

    source = await runLoader(source, loaderList)

    return source
}
复制代码
获取loader处理结果

使用await等待异步loader返回结果。这里有个问题,假如使用Array.prototype上的foreach方法,是一个同步方法,无法提供一个可由外部控制的异步环境,将传入的callback进行堵塞,因此此处采用了for-of进行循环。

async function analyzeFileToLoard(inputPath, outputPath) {
    let source = readFile(inputPath)
    const loaders = config.module
    for (let loader of loaders) {
        if (loader.test.test(inputPath)) {
            source = await useLoader(source, loader.loader, outputPath)
            if (loader.outputPath) outputPath = loader.outputPath(outputPath)
        }
    }

    writeFile(outputAppPath(outputPath), source)
}
复制代码
改进异步asyncForeach方法

可以用之前foreach的习惯调用。

Array.prototype.asyncForeach = async function(callBack) {
    if (callBack.constructor.name !== 'AsyncFunction') throw new Error('callBack should be AsyncFunction!')
    for (let i = 0; i<this.length; i ++ ) {
        const item = this[i]
        await callBack(item, i)
    }
}

// 调用
async function analyzeFileToLoard(inputPath, outputPath) {
    let source = readFile(inputPath)
    const loaders = config.module

    await loaders.asyncForeach(async loader => {
        if (loader.test.test(inputPath)) {
            const res = await useLoader(source, loader.loader, outputPath)
            source = res
            if (loader.outputPath) outputPath = loader.outputPath(outputPath)
        }
    })
    writeFile(outputAppPath(outputPath), source)
}

相关案例查看更多