Відповіді:
Вам може сподобатися:
window.open('url', 'window name', 'window settings')
jQuery:
$('a#link_id').click(function(){
window.open('url', 'window name', 'window settings');
return false;
});
Крім того, можна встановити targetна _blankнасправді.
Ось як примусити ціль всередині обробника клацання:
$('a#link_id').click(function() {
$(this).attr('target', '_blank');
});
$(this).attr('target', '_blank'); можна було змінити на this.target = "_blank";Крім того, якщо прив'язувальні посилання на сторінці можна змінити, щоб мати rel="external"атрибути, тоді ви можете створити глобальний обробник кліків для сторінки за допомогою селектора jQuery, a[rel="external"]а не мати обробник a#link_id
вам потрібно буде використовувати window.open(url);
посилання:
http://www.htmlcodetutorial.com/linking/linking_famsupp_120.html
http://www.w3schools.com/jsref/met_win_open.asp
Я просто знайшов цікаве рішення цього питання. Я створював інтервали, які містять інформацію на основі повернення від веб-служби. Я думав про спробу встановити посилання навколо проміжку, щоб, якщо я натиснув на нього, "a" зафіксував клацання.
Але я намагався зафіксувати клацання з інтервалом ... тому я подумав, чому б не зробити цього, коли створював інтервал.
var span = $('<span id="something" data-href="'+url+'" />');
Потім я прив’язав обробник кліків до інтервалу, який створив посилання на основі атрибута 'data-href':
span.click(function(e) {
e.stopPropagation();
var href = $(this).attr('data-href');
var link = $('<a href="http://' + href + '" />');
link.attr('target', '_blank');
window.open(link.attr('href'));
});
Це вдало дозволило мені натиснути на інтервал і відкрити нове вікно з відповідною URL-адресою.
В чому проблема <a href="myurl.html" target="_blank">My Link</a>? Не потрібен Javascript ...
це рішення також розглядало випадок, коли url порожній, а відключене (сіре) порожнє посилання.
$(function() {
changeAnchor();
});
function changeAnchor() {
$("a[name$='aWebsiteUrl']").each(function() { // you can write your selector here
$(this).css("background", "none");
$(this).css("font-weight", "normal");
var url = $(this).attr('href').trim();
if (url == " " || url == "") { //disable empty link
$(this).attr("class", "disabled");
$(this).attr("href", "javascript:void(0)");
} else {
$(this).attr("target", "_blank");// HERE set the non-empty links, open in new window
}
});
}
a.disabled {
text-decoration: none;
pointer-events: none;
cursor: default;
color: grey;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<a name="aWebsiteUrl" href="http://www.baidu.com" class='#'>[website]</a>
<a name="aWebsiteUrl" href=" " class='#'>[website]</a>
<a name="aWebsiteUrl" href="http://www.alibaba.com" class='#'>[website]</a>
<a name="aWebsiteUrl" href="http://www.qq.com" class='#'>[website]</a>
Майте на увазі, якщо ви хочете виконувати запити AJAX усередині функції обробника події для події кліку. З якоїсь причини Chrome (і, можливо, інші браузери) не відкриє нову вкладку / вікно.
Це не дуже приємне виправлення, але воно працює:
CSS:
.new-tab-opener
{
display: none;
}
HTML:
<a data-href="http://www.google.com/" href="javascript:">Click here</a>
<form class="new-tab-opener" method="get" target="_blank"></form>
Javascript:
$('a').on('click', function (e) {
var f = $('.new-tab-opener');
f.attr('action', $(this).attr('data-href'));
f.submit();
});
Приклад в реальному часі : http://jsfiddle.net/7eRLb/
Microsoft IE не підтримує ім'я як другий аргумент.
window.open('url', 'window name', 'window settings');
Проблема в тому window name . Це буде працювати:
window.open('url', '', 'window settings')
Корпорація Майкрософт допускає лише такі аргументи, якщо взагалі використовувати цей аргумент: