Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #11 (permalink)  
Старый 25.09.2008, 22:06
Отправить личное сообщение для Андрей Параничев Посмотреть профиль Найти все сообщения от Андрей Параничев
 
Регистрация: 21.02.2008
Сообщений: 1,250

alpar_andr,
Сделайте "заглушку" для Safari.
<a href="http://link_to_profile/" target="_blank" onclick="window.open(...)">ссылка</a>

Тогда в сафари будет открываться ссылка в новом окне по ссылке, в других браузерах - ваше окно по window.open(). Только возвращайте в обработчик false если неудалось открыть window.open() (как в случае заглушек для браузеров с отключенным JavaScript).
Ответить с цитированием
  #12 (permalink)  
Старый 25.09.2008, 22:31
Кандидат Javascript-наук
Отправить личное сообщение для magistr_bender Посмотреть профиль Найти все сообщения от magistr_bender
 
Регистрация: 07.09.2008
Сообщений: 133

ну могу предложить создавать динамически элемент ну например табличку с профием.. очень удобно будет.. и главное ненадо никаких дополнительных окон... и таблицку эту всегда можно будет с лёгкостью уничтожить...
приведу пример такой таблицы
<head>
  <title></title>
  <style>
  #vjt-table-top{
    background-image: url(skins/standart/images/22.png); background-repeat: repeat-x; width: 100%
  }
  #vjt-table-left{
    background-image: url(skins/standart/images/25.png); background-repeat: repeat-y; height: 200px
  }
  #vjt-table-right{
    background-image: url(skins/standart/images/26.png); background-repeat: repeat-y
  }
  #vjt-table-bottom{
    background-image: url(skins/standart/images/27.png); background-repeat: repeat-x
  }
  #vij-table{
    width: 500px
  }
  #vij-table-ie{
    cellpadding: 0px; cellspacing: 0px; padding: 0 0 0 0; margin: 0 0 0 0;
  }
  .vjt-img{
    border: 0;
  }


  </style>
</head>

<body>
<input type="submit" value="Create" name="create" onclick="create_elem()" />
<input type="submit" value="Destroy" name="destroy" onclick="destroy_elem()" />
<script language="JavaScript" type="text/javascript">
var moveState = false;

var x0, y0;
var divX0, divY0;
function defPosition(event) {
    var x = y = 0;
    if (document.attachEvent != null) { // Internet Explorer & Opera
        x = window.event.clientX + document.documentElement.scrollLeft + document.body.scrollLeft;
        y = window.event.clientY + document.documentElement.scrollTop + document.body.scrollTop;
    }
    if (!document.attachEvent && document.addEventListener) { // Gecko
        x = event.clientX + window.scrollX;
        y = event.clientY + window.scrollY;
    }
    return {x:x, y:y};
}

function initMove(div, event) {

    var event = event || window.event;
    x0 = defPosition(event).x;
    y0 = defPosition(event).y;
    divX0 = parseInt(div.style.left);
    divY0 = parseInt(div.style.top);
    moveState = true;
}

document.onmouseup = function() {
    moveState = false;
}

function moveHandler(div, event) {
    var event = event || window.event;
    if (moveState) {
        div.style.left = divX0 + defPosition(event).x - x0;
        div.style.top  = divY0 + defPosition(event).y - y0;
    }
}


var vjtwindow;

function create_elem() {
var mdiv = document.getElementById("mdiv");
    if (!vjtwindow) {
        vjtwindow=document.createElement("table");
        vjtwindow.cellPadding = 0;
        vjtwindow.cellSpacing = 0;
        vjtwindow.id = "vij-table";
        vjtwindow.name = "vij-table";

    var newRow=vjtwindow.insertRow(0);
    var newCell = newRow.insertCell(0);
        newCell.id="vij-table-ie";
        newCell.innerHTML="<img src=\"skins/standart/images/21.png\" class=\"vjt-img\"/>";

    var newCell = newRow.insertCell(1);
        newCell.id="vjt-table-top";
        newCell.innerHTML="";

    var newCell = newRow.insertCell(2);
        newCell.id="vij-table-ie";
        newCell.innerHTML="<img src=\"skins/standart/images/24.png\" class=\"vjt-img\"/>";

    var newRow=vjtwindow.insertRow(1);
    var newCell = newRow.insertCell(0);
        newCell.id="vij-table-ie";
        newCell.innerHTML="<img src=\"skins/standart/images/29.png\" class=\"vjt-img\"/>";

    var newCell = newRow.insertCell(1);
        newCell.id="vjt-table-bottom";
        newCell.innerHTML="";

    var newCell = newRow.insertCell(2);
        newCell.id="vij-table-ie";
        newCell.innerHTML="<img src=\"skins/standart/images/28.png\" class=\"vjt-img\"/>";

    var newRow=vjtwindow.insertRow(1);
    var newCell = newRow.insertCell(0);
        newCell.id="vjt-table-left";
        newCell.innerHTML="";

    var newCell = newRow.insertCell(1);
        newCell.id="vjt-tab";
        newCell.setAttribute("vlign","top");
        newCell.innerHTML="<b>23</b>";

    var newCell = newRow.insertCell(2);
        newCell.id="vjt-table-right";
        newCell.innerHTML="";
    vjtwindow.position="absolute";
    document.getElementById("mdiv").appendChild(vjtwindow);
    }
}
function destroy_elem(){
    if (!vjtwindow) return;
    document.getElementById("mdiv").removeChild(vjtwindow);
    vjtwindow = null;
}

</script>
<div style='position:absolute; top:100px; left:100px; height: 500px; width:350px;' onmousedown = 'initMove(this, event);' onmouseup = 'moveState = false;' onmousemove = 'moveHandler(this, event);' id = 'mdiv'></div>
</body>

код работает во всех браузерах, только не оптимизирован...
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как сделать такую галерею crisco Events/DOM/Window 4 23.12.2008 16:28
Как сделать функцию типа toDataUrl для рисунка в ie6 ? Олег Общие вопросы Javascript 2 14.09.2008 00:06
вызов функции, из JS генерируемого на сервере subaru AJAX и COMET 1 12.07.2008 13:44
не понятная конструкция в JS scuter Общие вопросы Javascript 11 07.06.2008 14:07
Какой оператор на JS равняется оператору and? Forgott Общие вопросы Javascript 2 20.05.2008 10:15