Какой мой сценарий URL? - PullRequest
32 голосов
/ 12 июня 2009

Существует ли простой и надежный способ определения URL исполняемого в данный момент файла JavaScript (внутри веб-страницы)?

Моя единственная мысль по этому поводу состоит в том, чтобы сканировать DOM для всех атрибутов сценария src, чтобы найти ссылку на текущий файл, а затем определить абсолютный URL-адрес, применив его к document.location. У кого-нибудь есть другие идеи, есть ли какой-то супер-простой метод, который я полностью упустил из виду?

ОБНОВЛЕНИЕ: элементы скрипта, доступные через DOM, уже имеют свойство src, которое содержит полный URL-адрес. Я не знаю, насколько это вездесуще / стандартно, но в качестве альтернативы вы можете использовать getAttribute("src"), который будет возвращать любое необработанное значение атрибута в [X] HTML.

Ответы [ 6 ]

40 голосов
/ 12 июня 2009

Поместите это в файл js, который должен знать свой собственный URL.

Полностью квалифицированный (например, http://www.example.com/js/main.js):

var scriptSource = (function(scripts) {
    var scripts = document.getElementsByTagName('script'),
        script = scripts[scripts.length - 1];

    if (script.getAttribute.length !== undefined) {
        return script.src
    }

    return script.getAttribute('src', -1)
}());

Или Как указано в источнике (например, /js/main.js):

var scriptSource = (function() {
    var scripts = document.getElementsByTagName('script'),
        script = scripts[scripts.length - 1];

    if (script.getAttribute.length !== undefined) {
        return script.getAttribute('src')
    }

    return script.getAttribute('src', 2)
}());

См. http://www.glennjones.net/Post/809/getAttributehrefbug.htm для объяснения используемого параметра getAttribute (это ошибка IE).

31 голосов
/ 28 апреля 2014

Для последних браузеров вы можете использовать document.currentScript, чтобы получить эту информацию.

var mySource = document.currentScript.src;

Плюс в том, что он более надежен для скриптов, которые загружаются асинхронно. Недостатком является то, что он, как я знаю, не поддерживается повсеместно. Он должен работать на Chrome> = 29, FireFox> = 4, Opera> = 16. Как и многие другие полезные вещи, он не работает в IE.

Когда мне нужно получить путь к сценарию, я проверяю, определен ли document.currentScript, и, если нет, использую метод, описанный в принятом ответе.

if (document.currentScript) {
    mySource = document.currentScript.src;
} else {
    // code omitted for brevity
}

https://developer.mozilla.org/en-US/docs/Web/API/document.currentScript

6 голосов
/ 05 октября 2010

Как указано в источнике (например, /js/main.js), это кросс-браузер :

var scriptSource = (function() 
{ 
    var scripts = document.getElementsByTagName('script'), 
        script = scripts[scripts.length - 1]; 

    //No need to perform the same test we do for the Fully Qualified
    return script.getAttribute('src', 2); //this works in all browser even in FF/Chrome/Safari
}()); 

Полностью квалифицированный (например, http://www.example.com/js/main.js):

После некоторых тестов трудно получить полностью квалифицированную в кросс-браузерном режиме. Решение , предложенное Crescent Fresh , не работает в IE8 для получения полностью квалифицированного , даже если оно работает в IE7

5 голосов
/ 09 мая 2013

Этот метод работает с отложенной, асинхронной и отложенной загрузкой Так как вы знаете имя файла вашего скрипта, и будет ли он уникальным

/* see  
 * /696515/kakoi-moi-stsenarii-url#696522
 * http://www.glennjones.net/Post/809/getAttributehrefbug.htm
 * 
 * iterate all script to find script with right filename
 * this work with async and defer (but your script MUST have a unique filemane)
 * mozilla support document.currentScript and we use it, if is set
 *
 * this will not work with local script loaded by jQuery.getScript(),
 * since there is no script tag added into the dom. the script is only evaluated in global space.
 * http://api.jquery.com/jQuery.getScript/
 *  
 * to fix this odd, you can add a reference in meta ( meta[name=srcipt][content=url] )
 * when you load the script
 */
var scriptFilename = 'jquery.plugins.template.js'; // don't forget to set the filename 
var scriptUrl = (function() {
    if (document.currentScript) { // support defer & async (mozilla only)
        return document.currentScript.src;
    } else {
        var ls,s;
        var getSrc = function (ls, attr) {
            var i, l = ls.length, nf, s;
            for (i = 0; i < l; i++) {
                s = null;
                if (ls[i].getAttribute.length !== undefined) { 
                    s = ls[i].getAttribute(attr, 2);                    
                }               
                if (!s) continue; // tag with no src
                nf = s;
                nf = nf.split('?')[0].split('/').pop(); // get script filename
                if (nf === scriptFilename) {
                    return s;
                }
            }
        };          
        ls = document.getElementsByTagName('script');
        s = getSrc(ls, 'src');
        if ( !s ) { // search reference of script loaded by jQuery.getScript() in meta[name=srcipt][content=url]
            ls = document.getElementsByTagName('meta');             
            s = getSrc(ls, 'content');
        }           
        if ( s ) return s;
    }
    return '';
})();

var scriptPath =  scriptUrl.substring(0, scriptUrl.lastIndexOf('/'))+"/";

шаблон плагина jquery с ним: https://github.com/mkdgs/mkdgs-snippet/blob/master/javascript/jquery.plugins.template.js

примечание: это не будет работать с локальным скриптом, загруженным jQuery.getScript (), так как в dom нет тега скрипта скрипт оценивается только в глобальном пространстве. http://api.jquery.com/jQuery.getScript/

чтобы исправить это, вы можете сделать что-то вроде:

function loadScript(url,callback) {     

    if ( $('[src="'+url+'"]').length ) return true; // is already loaded    

    // make a reference of the loaded script
    if ( $('meta[content="'+url+'"]', $("head")).length ) return true; // is already loaded 
    var meta = document.createElement('meta');
    meta.content = url;
    meta.name = 'script';
    $("head").append(meta);

    return $.ajax({
          cache: true,
          url: u,
          dataType: 'script',
          async: false,
          success : function (script) {                     
                try { 
                    if ( typeof callback == 'function' ) callback();    
                } catch (error) { 
                    //console.log(error);
                }
          }
     });
}
0 голосов
/ 12 июня 2009

Возможно, вы захотите взглянуть на https://addons.mozilla.org/en-US/firefox/addon/10345, если вам интересно узнать, какие функции (и, следовательно, какой файл) выполняются на странице, которую вы не контролируете.

Если вам интересно выяснить, какой из ваших сценариев выполняется, то есть несколько способов. С Firebug вы можете console.log() информацию. Даже просто добавив в код операторы предупреждений (хотя это и раздражает), вы сможете отлаживать их с минимальными затратами. Вы также можете вызвать ошибки и перехватить их, а затем обработать, используя свойства ошибки (см .: https://developer.mozilla.org/en/Core_JavaScript_1.5_Reference/Global_Objects/Error)

Однако почему это важно? Если скрипт уже вызывает ошибки, то достаточно легко определить, где происходит ошибка. Если дело совсем не в ошибках, то в чем преимущество знания того, из какого файла он взялся?

0 голосов
/ 12 июня 2009

Если это строго клиентское решение, ваше звучит неплохо.

Если вы пишете код на сервере, вы, вероятно, могли бы просто заполнить поле div / hidden / (вставьте здесь свой любимый HTML-элемент) полностью разрешенным URL-адресом сценария и получить его с помощью JavaScript на клиентской стороне. .

...