Показать сообщение отдельно
  #1 (permalink)  
Старый 16.09.2008, 11:01
Новичок на форуме
Отправить личное сообщение для Kaito Посмотреть профиль Найти все сообщения от Kaito
 
Регистрация: 16.09.2008
Сообщений: 1

Всплывающая подсказка
Помогите пожалуйста разобраться с подсказкой. Два дня сам мучал ничего не получается. Javascript на нулевом уровне пока.
1. Над, чтоб подсказка появлялась не "справа-ниже" от курсора, а "справа-выше". Тобиш получается, что мне над знать высоту подсказки чтоли...А как? Данные у меня динамически заполняется из мускула.
2. Как сделать чтоб когда курсор находится над подсказкой то подсказка не пряталась.
3. И как сделать чтоб когда курсор находится над подсказкой при щелчке мышкой подсказка бы пряталась

var myprompt=document.createElement('div');
myprompt.id='prompt';
myprompt.style.display='none';
myprompt.style.position='absolute';
myprompt.style.top='0px';
myprompt.style.left='0px';
myprompt.show_delay=100;
myprompt.hide_delay=0;
myprompt.cursor_shiftX=20;
myprompt.cursor_shiftY=0;
myprompt.prompt_elements=new Array('a');

function showPrompt(event){
    if(!event) event=window.event;
    if(myprompt.mustShow==undefined){
        if(myprompt.timer_id){
            window.clearInterval(myprompt.timer_id);
            myprompt.mustHide=undefined;
        }
        myprompt.next_message=this.prompt_text;
        myprompt.mustShow=true;
        myprompt.oldX=event.clientX+document.body.scrollLeft;
        myprompt.oldY=event.clientY+document.body.scrollTop;
        myprompt.timer_id=window.setInterval('showPrompt();',myprompt.show_delay);
    }else{
        window.clearInterval(myprompt.timer_id);
        myprompt.innerHTML=myprompt.next_message;
        myprompt.timer_id=undefined;
        myprompt.mustShow=undefined;
        myprompt.style.left=(myprompt.oldX+myprompt.cursor_shiftX)+'px';
        myprompt.style.top=(myprompt.oldY+myprompt.cursor_shiftY)+'px';
        myprompt.style.display='block';
    }
}
function hidePrompt(){
    if(myprompt.mustHide==undefined){
        if(myprompt.timer_id){
            window.clearInterval(myprompt.timer_id);
            myprompt.mustShow=undefined;
        }
        myprompt.mustHide=true;
        myprompt.timer_id=window.setInterval('hidePrompt();',myprompt.hide_delay);
    }else{
        window.clearInterval(myprompt.timer_id);
        myprompt.timer_id=undefined;
        myprompt.mustHide=undefined;
        myprompt.style.display='none';
    }
}
function refreshPromptCoords(event){
    if(myprompt.mustShow==undefined) return;
    if(!event) event=window.event;
    myprompt.oldX=event.clientX+document.body.scrollLeft;
    myprompt.oldY=event.clientY+document.body.scrollTop;
}
function setPromptEvents(){
    document.body.appendChild(myprompt);
    for(var k=0; k<myprompt.prompt_elements.length; k++){
        var anchors=document.getElementsByTagName(myprompt.prompt_elements[k]);
        for(var i=0; i<anchors.length; i++){
            var spans=anchors[i].getElementsByTagName('span');
            if(spans.length==0) continue;
            for(var j=0; j<spans.length; j++){
                if(spans[j].className=='prompt'){
                    anchors[i].prompt_text=spans[j].innerHTML;
                    break;
                }
            }
            if(!anchors[i].prompt_text) continue;
            anchors[i].onmouseover=showPrompt;
            anchors[i].onmouseout=hidePrompt;
            anchors[i].onmousemove=refreshPromptCoords;
        }
    }
}
if (typeof document.attachEvent!='undefined') window.attachEvent('onload',setPromptEvents);
else window.addEventListener('load',setPromptEvents,false);


вызывается как:

<style type="text/css">
div#prompt { padding: 4px;background:#FCF1C3;border:1px solid #999999;font-size:11px;color:#555555;width: 250px; }
span.prompt { display:none; }
</style>

<a href="">текст <span class="prompt">подсказка</span></a>
Ответить с цитированием