prototype - javascript 库原型(prototype)函数没有一个接一个地执行

标签 prototype javascript

我正在开发一个 JavaScript 库。这是基本代码:

(function(){
        var int,
            method,
            Jist = function(s){
                return new Jist.fn.init(s);
            };
        Jist.fn = Jist.prototype ={
            init : function(s){
                if(!s){
                    return this;
                }
                else{
                    this.length = 1;
                    if (typeof s === "object"){
                        this[0] = s;
                    }
                    else if(typeof s === "string"){
                        var obj;
                        obj = document.querySelectorAll(s);
                        this[0] = obj;
                        this.elem = this[0];
                    }
                    return this;
                }
            },
        }
        Jist.fn.init.prototype = Jist.fn;
        Jist.fn.init.prototype = {
            print : function(txt){
                for(var i=0; i<this.elem.length; i++) {
                    this.elem[i].innerHTML = txt;
                }
                return this;
            },
            click : function(callback){
                for(var i=0; i<this.elem.length; i++) {
                    this.elem[i].addEventListener("click",callback,false);
                }
                return this;
            },
            fadeOut : function(ms) {
                var elem = this.elem;
                var opacity = 1,
                    interval = 50,
                    gap = interval / ms;
                function func() { 
                    opacity -= gap;
                    for(var i=0; i<elem.length; i++) {
                        elem[i].style.opacity = opacity;
                    }
                    if(opacity <= 0) {
                        window.clearInterval(fading); 
                        for(var i=0; i<elem.length; i++){
                            elem[i].style.display = 'none';
                        }
                    }
                }
                var fading = window.setInterval(func, interval);
                return this;
            },
            fadeIn : function(ms) {
                var opacity = 0,
                    interval = 50,
                    gap = interval / ms,

                    elem = this.elem;
                    for(var i=0; i<elem.length; i++){
                        elem[i].style.display = 'block';
                        elem[i].style.opacity = opacity;
                    }
                function func() { 
                    opacity += gap;
                    for(var i=0; i<elem.length; i++){
                        elem[i].style.opacity = opacity;
                    }
                    if(opacity >= 1) {
                        window.clearInterval(fading);
                    }
                }
                var fading = window.setInterval(func, interval);
                return this;
            }
        };
        window.Jist = window.jist = window.Jis = window.jis = window.Jit = window.jit = window._ = Jist;
})();

这是我在正文部分测试该库的内容:

<div id="fader"></div>
<input type="button" id="inpt" value="click"></input>
<script>
jist("#inpt").click(function(){
    jist("#fader").print("FooBar").fadeOut(1000).fadeIn(1000).print("");
});
</script>

jist("#fader").print("FooBar").fadeOut(1000).fadeIn(1000).print(""); 应该放置文本div 中的“FooBar”(确实如此)然后淡出,然后淡入并删除 div 中的文本。

但相反,它开始淡出,然后很快尝试淡出。这是因为所有函数都是同时执行的,而不是一个接一个地执行。

有谁知道我如何更改我的库以便发生这种情况?这是一个类似 jQuery 的库,所以我希望它的工作方式与查询类似。

非常感谢!

最佳答案

我不会讨论你的长代码,但这里是你应该如何做的简短示例

// this is how you do it
m1.myFirst().mySecond();

//this is via callback
m2.myFirst(function(){
    m2.mySecond();
});

fiddle

关于prototype - javascript 库原型(prototype)函数没有一个接一个地执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19589771/

相关文章:

javascript - 如何使用 jQuery .data() 函数访问元素的原型(prototype)?

javascript - 为什么这种行为?__proto__ vs 原型(prototype)?

javascript - 在数组中对值进行排序后,保留键及其值吗?

javascript - 如何停止带有 li 元素的非常基本的 slider 中的无限幻灯片?

javascript - 如何使用 jquery 工具提示显示错误消息?

javascript - 如何在行尾添加新的子DIV?

javascript - Angular或js如何在不指定参数名的情况下返回数据

javascript - 构造函数的继承属性

javascript - JavaScript 中特定时区的 new Date()

javascript - Javascript 中的原型(prototype)有什么作用?