Форум АНТИЧАТ

Форум АНТИЧАТ (https://forum.antichat.xyz/index.php)
-   PHP, PERL, MySQL, JavaScript (https://forum.antichat.xyz/forumdisplay.php?f=37)
-   -   [JS] - Tooltip (https://forum.antichat.xyz/showthread.php?t=60966)

Isis 04.02.2008 14:51

[JS] - Tooltip
 
Все наверно знают js скрипт tooltip
Код HTML:

/*
originally written by paul sowden <paul@idontsmoke.co.uk> | http://idontsmoke.co.uk
modified and localized by alexander shurkayev <alshur@narod.ru> | http://htmlcoder.visions.ru
*/

var tooltip = {

        options: {
                attr_name: "tooltip", // наименование создаваемого tooltip'ого атрибута
                blank_text: "(open in new window)", // текст для ссылок с target="_blank"
                newline_entity: ":::", // укажите пустую строку (""), если не хотите использовать в tooltip'ах многострочность; ежели хотите, то укажите тот символ или символы, которые будут заменяться на перевод строки
                max_width: 0, // максимальная ширина tooltip'а в пикселах; обнулите это значение, если ширина должна быть нелимитирована
                delay: 0, // задержка при показе tooltip'а в миллисекундах
                skip_tags: ["link", "style"] // теги, у которых не обрабатываем атрибуты alt и title
        },

        t: document.createElement("DIV"),
        c: null,
        g: false,
        canvas: null,

        m: function(e){
                if (tooltip.g){
                        var x = window.event ? event.clientX + tooltip.canvas.scrollLeft : e.pageX;
                        var y = window.event ? event.clientY + tooltip.canvas.scrollTop : e.pageY;
                        tooltip.a(x, y);
                }
        },

        d: function(){
                tooltip.canvas = document.getElementsByTagName(document.compatMode && document.compatMode == "CSS1Compat" ? "HTML" : "BODY")[0];
                tooltip.t.setAttribute("id", "tooltip");
                document.body.appendChild(tooltip.t);
                if (tooltip.options.max_width) tooltip.t.style.maxWidth = tooltip.options.max_width + "px"; // all but ie
                var a = document.all && !window.opera ? document.all : document.getElementsByTagName("*"); // in opera 9 document.all produces type mismatch error
                var l = a.length;
                for (var i = 0; i < l; i++){

                        if (!a[i] || tooltip.options.skip_tags.in_array(a[i].tagName.toLowerCase())) continue;
                       
                        var tooltip_title = a[i].getAttribute("title"); // returns form object if IE & name="title"; then IE crashes; so...
                        if (tooltip_title && typeof tooltip_title != "string") tooltip_title = "";

                        var tooltip_alt = a[i].getAttribute("alt");
                        var tooltip_blank = a[i].getAttribute("target") && a[i].getAttribute("target") == "_blank" && tooltip.options.blank_text;
                        if (tooltip_title || tooltip_blank){
                                a[i].setAttribute(tooltip.options.attr_name, tooltip_blank ? (tooltip_title ? tooltip_title + " " + tooltip.options.blank_text : tooltip.options.blank_text) : tooltip_title);
                                if (a[i].getAttribute(tooltip.options.attr_name)){
                                        a[i].removeAttribute("title");
                                        if (tooltip_alt && a[i].complete) a[i].removeAttribute("alt");
                                        tooltip.l(a[i], "mouseover", tooltip.s);
                                        tooltip.l(a[i], "mouseout", tooltip.h);
                                }
                        }else if (tooltip_alt && a[i].complete){
                                a[i].setAttribute(tooltip.options.attr_name, tooltip_alt);
                                if (a[i].getAttribute(tooltip.options.attr_name)){
                                        a[i].removeAttribute("alt");
                                        tooltip.l(a[i], "mouseover", tooltip.s);
                                        tooltip.l(a[i], "mouseout", tooltip.h);
                                }
                        }
                        if (!a[i].getAttribute(tooltip.options.attr_name) && tooltip_blank){
                                //
                        }
                }
                document.onmousemove = tooltip.m;
                window.onscroll = tooltip.h;
                tooltip.a(-99, -99);
        },
       
        _: function(s){
                s = s.replace(/\&/g,"&amp;");
                s = s.replace(/\</g,"&lt;");
                s = s.replace(/\>
/g,"&gt;");
                return s;
        },

        s: function(e){
                if (typeof tooltip == "undefined") return;
                var d = window.event ? window.event.srcElement : e.target;
                if (!d.getAttribute(tooltip.options.attr_name)) return;
                var s = d.getAttribute(tooltip.options.attr_name);
                if (tooltip.options.newline_entity){
                        var s = tooltip._(s);
                        s = s.replace(eval("/" + tooltip._(tooltip.options.newline_entity) + "/g"), "<br />");
                        tooltip.t.innerHTML = s;
                }else{
                        if (tooltip.t.firstChild) tooltip.t.removeChild(tooltip.t.firstChild);
                        tooltip.t.appendChild(document.createTextNode(s));
                }
                tooltip.c = setTimeout("tooltip.t.style.visibility = 'visible'", tooltip.options.delay);
                tooltip.g = true;
        },

        h: function(e){
                if (typeof tooltip == "undefined") return;
                tooltip.t.style.visibility = "hidden";
                if (!tooltip.options.newline_entity && tooltip.t.firstChild) tooltip.t.removeChild(tooltip.t.firstChild);
                clearTimeout(tooltip.c);
                tooltip.g = false;
                tooltip.a(-99, -99);
        },

        l: function(o, e, a){
                if (o.addEventListener) o.addEventListener(e, a, false); // was true--Opera 7b workaround!
                else if (o.attachEvent) o.attachEvent("on" + e, a);
                        else return null;
        },

        a: function(x, y){
                var w_width = tooltip.canvas.clientWidth ? tooltip.canvas.clientWidth + tooltip.canvas.scrollLeft : window.innerWidth + window.pageXOffset;
                var w_height = window.innerHeight ? window.innerHeight + window.pageYOffset : tooltip.canvas.clientHeight + tooltip.canvas.scrollTop; // should be vice verca since Opera 7 is crazy!

                if (document.all && document.all.item && !window.opera) tooltip.t.style.width = tooltip.options.max_width && tooltip.t.offsetWidth > tooltip.options.max_width ? tooltip.options.max_width + "px" : "auto";
               
                var t_width = tooltip.t.offsetWidth;
                var t_height = tooltip.t.offsetHeight;

                tooltip.t.style.left = x + 8 + "px";
                tooltip.t.style.top = y + 8 + "px";
               
                if (x + t_width > w_width) tooltip.t.style.left = w_width - t_width + "px";
                if (y + t_height > w_height) tooltip.t.style.top = w_height - t_height + "px";
        }
}

Array.prototype.in_array = function(value){
        var l = this.length;
        for (var i = 0; i < l; i++)
                if (this[i] === value) return true;
        return false;
};

var root = window.addEventListener || window.attachEvent ? window : document.addEventListener ? document : null;
if (root){
        if (root.addEventListener) root.addEventListener("load", tooltip.d, false);
        else if (root.attachEvent) root.attachEvent("onload", tooltip.d);
}

необходимо как-то его дополнить так, чтобы можно было писать массив не только тэгов у которых не делать тултип ( skip_tags: ["link", "style"] )
Но и id тэгов....
Т.е. мне необходимо чтобы у элемента <ims src="1.jpg" alt="xek" id="1" />
Не показывался тултип!

Просто не писать alt нельзя т.к. наршуаю правила xhtml....

Т.к. у меня элементов много..надо сделать массив этих id..
Вот :)

Helios 04.02.2008 15:04

Держи и не заморачивайся:
http://demos.mootools.net/Tips
Там весь процесс идет через title, а не через alt

Isis 04.02.2008 15:15

Мне так не подходит...

title у img быть не должно

http://validator.w3.org/check?uri=http://demos.mootools.net/Tips

astrologer 04.02.2008 16:18

Найти:
Код:

if (!a[i] || tooltip.options.skip_tags.in_array(a[i].tagName.toLowerCase())) continue;
Заменить на:
Код:

if (!a[i] || tooltip.options.skip_tags.in_array(a[i].tagName.toLowerCase()) || tooltip.options.skip_id.in_array(a[i].id)) continue;
Найти:
Код:

skip_tags: ["link", "style"] // теги, у которых не обрабатываем атрибуты alt и title
Заменить на:
Код:

skip_tags: ["link", "style"], // теги, у которых не обрабатываем атрибуты alt и title
skip_id: ["id1", "id2..."] // элементы с id из этого списка обрабатываться не будут

Так, на всякий случай про правила:
Код:

ID and NAME tokens must begin with a letter ([A-Za-z])
and may be followed by any number of letters,
digits ([0-9]), hyphens ("-"), underscores ("_"),
colons (":"), and periods (".").


Isis 04.02.2008 22:16

Что-то не выходит..
Все равно показывает

astrologer 04.02.2008 22:33

Цитата:

Сообщение от Isis
Что-то не выходит..
Все равно показывает

Полный код станицы, пожалуйста. Или ссылку.


Время: 01:59