npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

simple-task

v0.0.1

Published

A simple tool to make it easy to control async tasks.

Downloads

5

Readme

Task

Include the callbacks,queue,promise,async(series,waterfall,parallel,parallelLimit...others're coming)

Make it easy to control the process :).

包含了这些模块: callbacks,queue,promise,async(series...添加中)

专为异步流程控制,如此简单 :)。

It's api like jQuery and async.
api 跟 jQuery 和 async 类似

Why chose task (为什么要使用task)?

Front end boom! There are many asynchronous library, promise, Co, async, Q and so on......
But! I am not used to, the original promise I think it is too difficult to use, CO to change my writing habits, async, yes, and async.
Async some parameters to pass null (or I'm not used at present? )! Almost anti human!

Here need to mention jQuery, I personally think jQuery too cock, not only is a DOM, a series of methods for built-in let me stop.
But! A lot of people think that jQuery is too low, just to those low level of slag to use, I use a JQ to be ready to be sprayed.

Think of a piece here:
-- colleague A points to a special Xuan to ask: "you don't have to JQ can make this come out?""
-- Thinking for a long time... Don't leave JQ ah, simply wrote the first JQ.
Of course I can't write it out.

So, the task of this article, just make me feel good, and I like to use, asynchronous process control aspects of the API, with my way to achieve it again!
I believe you will like it!


前端异常繁荣!异步库有很多,promise,co,async,Q 等等等等......
但是!我用不惯,原生的 promise 我觉得太难用了,co 要改变我的写作习惯,async,对,还有async。
async中一些参数要传null(或者是我目前没用到?)!简直反人类!

这里需要提一下 jQuery ,我个人觉得 jQuery 太屌,不仅仅是dom,内置的一系列方法让我欲罢不能。
但是!很多人觉得 jQuery 太low,只是给那些低水平的渣渣来用,我用个jq就要做好被喷的准备。

这里想起一个段子:
-- 同事A指着一个特别炫的轮显问:“你不用jq能把这个做出来么?”
-- 思考良久...离开jq搞不定啊,索性先写了个jq出来。
当然我是写不出来的。

So,本篇的task,只是把我觉得优秀的,且我喜欢用的,异步流程控制方面的api,用我的方式实现了一遍!

相信你也会喜欢! 

Api and demos, Api 和 例子

extension

Done,description is coming.
已完成,待添加描述。

tool

Done,description is coming.
已完成,待添加描述。

callbacks

Like jQuery.Callbacks,follow Pub/Sub
跟jq的callbacks很像,这里我看了它的代码,在我能看懂的范围内及其精简化。
主要就是观察者模式 (发布/订阅)。
    var cb = task.callbacks();

    cb.add(function(n){
        console.log(n);
    });

    cb.add(function(n){
        console.log(n*2);
    });

    cb.fire(1); 
    // out:
    // 1
    // 2
'once'
    var cb = task.callbacks('once');

    cb.add(function(n){
        console.log(n);
    });

    cb.fire(1);
    // 输出1,后面的代码没有效果
    // out:
    // 1

    cb.add(function(n){
        console.log(n*2);
    });

    cb.fire(1); 
    // nothing will happen
'memory'
    var cb = task.callbacks('memory');

    cb.add(function(n){
        console.log(n);
    });

    cb.fire(1);
    // out:
    // 1

    cb.add(function(n){
        console.log(n*2);
    });
    // out:
    // 2
and 'stopOnFalse' ... U know what it is.Stop when a function returns false;
还有 'stopOnFalse' ... 望文生义,某个function返回false的时候就停了。

All args can use together,split by space
所有的参数,都可以放在一起使用,用空格分离。
    var cb = task.callbacks('once memory'); //usefull,like a deferred! 很有用,有些类似deferred。

queue

Base method(基础的方法):
    var q = task.queue();

    for(var i=0;i<10;i++){
        q.queue(function(next,num){
            console.log(num);
            setTimeout(function(){
                next(num*2);
            },1);
        });
    }

    q.dequeue(1);
    // out:1 2 4 8 16 32 64 128 256 512
If u don't need params(如果不需要参数):    
    var q = task.queue();

    for(var i=0;i<10;i++){
        q.will(function(){
            console.log(new Date().getSeconds());
        }).delay(1000);
    }

    q.dequeue();
    // It likes a block~
    // 像闹钟一样,每秒打印一次
Error? 万一某个地方有错误呢?
Please use catch,请用catch

    var q = task.queue();

    q
    .queue(function(next){
        //......
        next();
    })
    .will(function(){
        throw Error("I'm a error!")
    })
    .will(function(){
        //......
    })
    .catch(function(err){
        console.log(err);
    })

    q.dequeue();
    // out:[Error: I'm a error!]

deferred

Done,description is coming.
已完成,待添加描述。

async

Done,description is coming.
已完成,待添加描述。

series

Done,description is coming.
已完成,待添加描述。

waterfall

Done,description is coming. 已完成,待添加描述。

parallel

Done,description is coming. 已完成,待添加描述。

parallelLimit

Done,description is coming. 已完成,待添加描述。