Make any link with .pdf open in new window with jQ

2019-01-19 03:45发布

问题:

How can I have all links with a .pdf file extension open in a new window using jQuery? I need to change this:

<a href="domain.com/pdf/parkingmap.pdf">parking map</a>

In to this:

<a href="domain.com/pdf/parkingmap.pdf" target="_blank">parking map</a>

All files are in a /pdf folder if that helps.

回答1:

To achieve this you can select any a element which has a href property ending with .pdf, and add a target="_blank" attribute to it. Try this:

$(function() {
    $('a[href$=".pdf"]').prop('target', '_blank');
});


回答2:

One way, assuming you want links not ending in pdf to open in the same page:

$('a').click(
    function(e){
        e.preventDefault();
        if (this.href.split('.').pop() === 'pdf') {
            window.open(this.href);
        }
        else {
            window.location = this.href;
        }
    });


回答3:

jQuery one-liner :

$('a[href$=".pdf"]').attr('target','_blank');

Also in vanilla Javascript :

[].filter.call(document.querySelectorAll('a'), function(a){
    return a.href.match('\\.pdf$') ? a.target = '_blank' : 0;
});

Or maybe :

var anchors = document.body.getElementsByTagName('a');
for (var i = 0; i < anchors.length; i++) {
    if(anchors[i].getAttribute('href').match('\\.pdf$') {
        anchors[i].setAttribute('target', '_blank');
    }
}

Try it here : http://codepen.io/gabssnake/pen/KyJxp