jQuery脚本兼容性问题

时间:2011-05-29 07:17:06

标签: jquery jquery-plugins

我是jQuery的新手,我遇到了一个我目前无法解决的问题 - 我集成了两个脚本(jquery supersized和highlightfade) - 不幸的是,我似乎遇到了让它们正常工作的问题。一旦我删除第一部分虽然(超大),另一个插件似乎运行良好。有什么问题?非常感谢一些帮助。

// jQuery supersized
jQuery(function ($) {
    $.supersized({
        slideshow: 1,
        autoplay: 1,
        start_slide: 1,
        random: 0,
        slide_interval: 4000,
        transition: 1,
        transition_speed: 1500,
        new_window: 1,
        pause_hover: 0,
        keyboard_nav: 1,
        performance: 1,
        image_protect: 1,
        image_path: 'img/',
        min_width: 0,
        min_height: 0,
        vertical_center: 1,
        horizontal_center: 1,
        fit_portrait: 1,
        fit_landscape: 0,
        navigation: 1,
        thumbnail_navigation: 1,
        slide_counter: 1,
        slide_captions: 1,
        slides: [{
            image: 'images/slides/1.jpg'
        }, {
            image: 'images/slides/2.jpg'
        }, {
            image: 'images/slides/3.jpg'
        }, {
            image: 'images/slides/4.jpg'
        }]
    });
});

// jQuery Plugin highlightFade (jquery.offput.ca/highlightFade)
jQuery.fn.highlightFade = function (settings) {
    var o = (settings && settings.constructor == String) ? {
        start: settings
    } : settings || {};
    var d = jQuery.highlightFade.defaults;
    var i = o['interval'] || d['interval'];
    var a = o['attr'] || d['attr'];
    var ts = {
        'linear': function (s, e, t, c) {
            return parseInt(s + (c / t) * (e - s))
        },
        'sinusoidal': function (s, e, t, c) {
            return parseInt(s + Math.sin(((c / t) * 90) * (Math.PI / 180)) * (e - s))
        },
        'exponential': function (s, e, t, c) {
            return parseInt(s + (Math.pow(c / t, 2)) * (e - s))
        }
    };
    var t = (o['iterator'] && o['iterator'].constructor == Function) ? o['iterator'] : ts[o['iterator']] || ts[d['iterator']] || ts['linear'];
    if (d['iterator'] && d['iterator'].constructor == Function) t = d['iterator'];
    return this.each(function () {
        if (!this.highlighting) this.highlighting = {};
        var e = (this.highlighting[a]) ? this.highlighting[a].end : jQuery.highlightFade.getBaseValue(this, a) || [255, 255, 255];
        var c = jQuery.highlightFade.getRGB(o['start'] || o['colour'] || o['color'] || d['start'] || [255, 255, 128]);
        var s = jQuery.speed(o['speed'] || d['speed']);
        var r = o['final'] || (this.highlighting[a] && this.highlighting[a].orig) ? this.highlighting[a].orig : jQuery.curCSS(this, a);
        if (o['end'] || d['end']) r = jQuery.highlightFade.asRGBString(e = jQuery.highlightFade.getRGB(o['end'] || d['end']));
        if (typeof o['final'] != 'undefined') r = o['final'];
        if (this.highlighting[a] && this.highlighting[a].timer) window.clearInterval(this.highlighting[a].timer);
        this.highlighting[a] = {
            steps: ((s.duration) / i),
            interval: i,
            currentStep: 0,
            start: c,
            end: e,
            orig: r,
            attr: a
        };
        jQuery.highlightFade(this, a, o['complete'], t)
    })
};
jQuery.highlightFade = function (e, a, o, t) {
    e.highlighting[a].timer = window.setInterval(function () {
        var newR = t(e.highlighting[a].start[0], e.highlighting[a].end[0], e.highlighting[a].steps, e.highlighting[a].currentStep);
        var newG = t(e.highlighting[a].start[1], e.highlighting[a].end[1], e.highlighting[a].steps, e.highlighting[a].currentStep);
        var newB = t(e.highlighting[a].start[2], e.highlighting[a].end[2], e.highlighting[a].steps, e.highlighting[a].currentStep);
        jQuery(e).css(a, jQuery.highlightFade.asRGBString([newR, newG, newB]));
        if (e.highlighting[a].currentStep++ >= e.highlighting[a].steps) {
            jQuery(e).css(a, e.highlighting[a].orig || '');
            window.clearInterval(e.highlighting[a].timer);
            e.highlighting[a] = null;
            if (o && o.constructor == Function) o.call(e)
        }
    }, e.highlighting[a].interval)
};
jQuery.highlightFade.defaults = {
    start: [255, 255, 128],
    interval: 50,
    speed: 400,
    attr: 'backgroundColor'
};
jQuery.highlightFade.getRGB = function (c, d) {
    var result;
    if (c && c.constructor == Array && c.length == 3) return c;
    if (result = /rgb(s*([0-9]{1,3})s*,s*([0-9]{1,3})s*,s*([0-9]{1,3})s*)/.exec(c)) return [parseInt(result[1]), parseInt(result[2]), parseInt(result[3])];
    else if (result = /rgb(s*([0-9]+(?:.[0-9]+)?)%s*,s*([0-9]+(?:.[0-9]+)?)%s*,s*([0-9]+(?:.[0-9]+)?)%s*)/.exec(c)) return [parseFloat(result[1]) * 2.55, parseFloat(result[2]) * 2.55, parseFloat(result[3]) * 2.55];
    else if (result = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(c)) return [parseInt("0x" + result[1]), parseInt("0x" + result[2]), parseInt("0x" + result[3])];
    else if (result = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(c)) return [parseInt("0x" + result[1] + result[1]), parseInt("0x" + result[2] + result[2]), parseInt("0x" + result[3] + result[3])];
    else return jQuery.highlightFade.checkColorName(c) || d || null
};
jQuery.highlightFade.asRGBString = function (a) {
    return "rgb(" + a.join(",") + ")"
};
jQuery.highlightFade.getBaseValue = function (e, a, b) {
    var s, t;
    b = b || false;
    t = a = a || jQuery.highlightFade.defaults['attr'];
    do {
        s = jQuery(e).css(t || 'backgroundColor');
        if ((s != '' && s != 'transparent') || (e.tagName.toLowerCase() == "body") || (!b && e.highlighting && e.highlighting[a] && e.highlighting[a].end)) break;
        t = false
    } while (e = e.parentNode);
    if (!b && e.highlighting && e.highlighting[a] && e.highlighting[a].end) s = e.highlighting[a].end;
    if (s == undefined || s == '' || s == 'transparent') s = [255, 255, 255];
    return jQuery.highlightFade.getRGB(s)
};
jQuery.highlightFade.checkColorName = function (c) {
    if (!c) return null;
    switch (c.replace(/^s*|s*$/g, '').toLowerCase()) {
    case 'aqua':
        return [0, 255, 255];
    case 'black':
        return [0, 0, 0];
    case 'blue':
        return [0, 0, 255];
    case 'fuchsia':
        return [255, 0, 255];
    case 'gray':
        return [128, 128, 128];
    case 'green':
        return [0, 128, 0];
    case 'lime':
        return [0, 255, 0];
    case 'maroon':
        return [128, 0, 0];
    case 'navy':
        return [0, 0, 128];
    case 'olive':
        return [128, 128, 0];
    case 'purple':
        return [128, 0, 128];
    case 'red':
        return [255, 0, 0];
    case 'silver':
        return [192, 192, 192];
    case 'teal':
        return [0, 128, 128];
    case 'white':
        return [255, 255, 255];
    case 'yellow':
        return [255, 255, 0]
    }
};

1 个答案:

答案 0 :(得分:3)

问题在于 highlightFade插件。你不需要那个。请浏览URL并查看插件的创建者所说的内容

  

YAY!这个插件终于实现了   obsolesence。 jQuery 1.2终于来了   经过漫长而旷日持久的1.1   发布并随之升级   效果系统。特别是它   现在允许自定义动画。约翰   Resig发布了官方jQuery   插件以及添加的1.2   边框和背景动画等   现在它比以前更好用   并且有完整的bemefit   支持jQuery团队。您可以   找到新官员的网站   jquery插件的动画插件   库。同时,老了   现在演示的主页   未维护的highlightFade插件即可   在这里找到

Link to the site