Arquivo da tag: Duplicado

Detectando arquivos Javascript duplicados na sua página, com Javascript!

JS
Nem vou comentar as possíveis razões do supracitado acontecimento, mas o fato é que, dependendo do projeto, você vai encontrar isso.

Os problemas? Muitos, a começar por funções chamadas duas ou mais vezes, isso quando eventos não são indevidamente inativados. Ok, chega de reclamar.

Após alguma pesquisa, consegue chegar a um bom código que consegue detectar arquivos js registrados na página. O mais bacana dele é que o código também detecta chamadas Ajax, ou seja, se algum bloco HTML for inserido dinamicamente, o código vai avisar!

O código:

// code to trigger ajax calls
(function () {
	var proxied = window.XMLHttpRequest.prototype.send;
	window.XMLHttpRequest.prototype.send = function () {
		console.log(arguments);
		//Here is where you can add any code to process the request. 
		//If you want to pass the Ajax request object, pass the 'pointer' below
		var pointer = this
		var intervalId = window.setInterval(function () {
			if (pointer.readyState != 4) {
				return;
			}
			// pointer.responseText <-- here is the response text
			checkDuplicatedScript();
			clearInterval(intervalId);
 
		}, 1);//I found a delay of 1 to be sufficient, modify it as you need.
		return proxied.apply(this, [].slice.call(arguments));
	};
})();
 
// check duplicated registered js files
function checkDuplicatedScript() {
	var arr = Array.prototype.slice.call(document.getElementsByTagName("script"), 0);
	var sorted_arr = arr.sort();
 
	var results = [];
	for (var i = 0; i < arr.length - 1; i++) {
		if (sorted_arr[i + 1].src == sorted_arr[i].src) {
			results.push(sorted_arr[i]);
		}
	}
 
	if (results.length > 0) {
		var message = 'These files as duplicated: ';
 
		results.forEach(function(element) {
			message += element.src + ',';
		}, this);
		alert(message);
	}
	else {
		console.log('Nothing here...., but the total was: ' +  sorted_arr.length);
	}
}
 
// for the first time
checkDuplicatedScript();

Como não poderia ser diferente, boa parte do código foi extraída do stackoverflow, com algumas alterações:

http://stackoverflow.com/questions/10783463/javascript-detect-ajax-requests
http://stackoverflow.com/questions/840781/easiest-way-to-find-duplicate-values-in-a-javascript-array

E também está no git!

https://github.com/Tomamais/detectDuplicatedJsFiles