[javascript] JavaScript에서 target =“_ blank”를 시뮬레이션하는 방법

사용자가 링크를 클릭하면 데이터베이스의 필드를 업데이트 한 다음 요청 된 링크를 새 창에서 열어야합니다. 업데이트는 문제가되지 않지만 다른 하이퍼 링크를 클릭하지 않고 새 창을 여는 방법을 모르겠습니다.

<body onLoad="document.getElementById('redirect').click">
<a href="http://www.mydomain.com?ReportID=1" id="redirect" target="_blank">Report</a>
</body>



답변

<script>
    window.open('http://www.example.com?ReportID=1', '_blank');
</script>

두 번째 매개 변수는 선택 사항이며 대상 창의 이름입니다.


답변

이것은 도움이 될 수 있습니다

var link = document.createElementNS("http://www.w3.org/1999/xhtml", "a");
    link.href = 'http://www.google.com';
    link.target = '_blank';
    var event = new MouseEvent('click', {
        'view': window,
        'bubbles': false,
        'cancelable': true
    });
    link.dispatchEvent(event);


답변

나는 이것이 완료되고 정리 된 거래라는 것을 알고 있지만 여기 내 앱의 문제를 해결하기 위해 사용하고있는 것이 있습니다.

if (!e.target.hasAttribute("target")) {
    e.preventDefault();     
    e.target.setAttribute("target", "_blank");
    e.target.click();
    return;
}

기본적으로 여기서 일어나는 일은 링크에 target=_blank속성 이 있는지 확인하는 것입니다. 그렇지 않으면 링크 트리거링을 중지하고 새 창에서 열도록 설정 한 다음 프로그래밍 방식으로 클릭합니다.

한 단계 더 나아가서 다음을 시도하여 원래 클릭 중지를 건너 뛸 수 있습니다 (그리고 코드를 훨씬 간단하게 만들 수 있습니다).

if (!e.target.hasAttribute("target")) {
    e.target.setAttribute("target", "_blank");
}

jQuery를 사용하여 속성 크로스 브라우저 추가 구현을 추상화하는 경우 다음 대신에 이것을 사용해야합니다 e.target.setAttribute("target", "_blank").

    jQuery(event.target).attr("target", "_blank")

정확한 사용 사례에 맞게 재 작업해야 할 수도 있지만 여기에 내 가려움증이 생겼습니다.

여기 당신이 엉망으로 만드는 데모 가 있습니다.

(jsfiddle의 링크는이 토론으로 돌아갑니다. 새 탭이 필요 없습니다.)


답변

단일 링크에 대한 것이라면 개인적으로 다음 코드를 사용하는 것이 좋습니다. 그렇지 않으면 비슷한 코드로 함수를 만드는 것이 가장 좋습니다.

onclick="this.target='_blank';"

나는 그것을 W3C의 XHTML 엄격한 테스트를 우회하기 위해 사용하기 시작했다.


답변

이것이 jQuery로 수행하는 방법입니다. 새 창에서 열려는 각 링크에 대한 클래스가 있습니다.

$(function(){

    $(".external").click(function(e) {
        e.preventDefault();
        window.open(this.href);
    });
});


답변

a 태그에서 href를 추출 할 수 있습니다.

window.open(document.getElementById('redirect').href);


답변

이렇게하면 모든 페이지 링크여는 데 도움이 될 수 있습니다 .

$(".myClass").each(
     function(i,e){
        window.open(e, '_blank');
     }
);

<a href="" class="myClass"></a>링크 항목을 클릭 한 것처럼 다른 탭에 대한 모든 링크 항목 이 열립니다 .

브라우저 콘솔에만 붙여 넣기 만하면됩니다. 필요한 jQuery 프레임 워크