Reputation: 303
I have a function that uses regex to return root domain of the given url.
function cleanUp(url) {
url = url.replace(new RegExp(/^\s+/),""); // START
url = url.replace(new RegExp(/\s+$/),""); // END
// IF FOUND, CONVERT BACK SLASHES TO FORWARD SLASHES
url = url.replace(new RegExp(/\\/g),"/");
// IF THERE, REMOVES 'http://', 'https://' or 'ftp://' FROM THE START
url = url.replace(new RegExp(/^http\:\/\/|^https\:\/\/|^ftp\:\/\//i),"");
// IF THERE, REMOVES 'www.' FROM THE START OF THE STRING
url = url.replace(new RegExp(/^www\./i),"");
//remove slash from end
url = url.replace(new RegExp(/\/$/i),"");
return url;
}
But it uses multi regex and we are worried about the performance. Is there a better way to do the same in a one line regex?
Note:
document.location.host does not seem to work in my case.
Upvotes: 3
Views: 8622
Reputation: 4249
Extract hostname name from string
Try:
function cleanUp(url) {
var url = $.trim(url);
if(url.search(/^https?\:\/\//) != -1)
url = url.match(/^https?\:\/\/([^\/?#]+)(?:[\/?#]|$)/i, "");
else
url = url.match(/^([^\/?#]+)(?:[\/?#]|$)/i, "");
return url[1];
}
alert(cleanUp(' http://www.google.com/about.html'));
alert(cleanUp(' www.google.com/about.html'));
Upvotes: 5
Reputation: 6003
Try this:
http://jsfiddle.net/picklespy/gb34u/1/
It works on all modern browsers and even on IE 5.5+.
var url = document.createElement('a');
url.href = 'http://maps.test.google.com';
var host = url.hostname;
host = host.split('.');
var domain = host.pop();
domain = host.pop() + '.' + domain;
alert('Root is: ' + domain)
Upvotes: 1