2-е оновлення: Намагаючись надати вичерпну відповідь, я аналізую три методи, запропоновані в різних відповідях.
var testURL = '/Products/List?SortDirection=dsc&Sort=price&Page=3&Page2=3';
var i;
// Testing the substring method
i = 0;
console.time('10k substring');
while (i < 10000) {
testURL.substring(0, testURL.indexOf('?'));
i++;
}
console.timeEnd('10k substring');
// Testing the split method
i = 0;
console.time('10k split');
while (i < 10000) {
testURL.split('?')[0];
i++;
}
console.timeEnd('10k split');
// Testing the RegEx method
i = 0;
var re = new RegExp("[^?]+");
console.time('10k regex');
while (i < 10000) {
testURL.match(re)[0];
i++;
}
console.timeEnd('10k regex');
Результати в Firefox 3.5.8 на Mac OS X 10.6.2:
10k substring: 16ms
10k split: 25ms
10k regex: 44ms
Результати в Chrome 5.0.307.11 на Mac OS X 10.6.2:
10k substring: 14ms
10k split: 20ms
10k regex: 15ms
Зауважте, що метод підрядки поступається функціональним функціям, оскільки він повертає порожній рядок, якщо URL-адреса не містить рядка запиту. Інші два способи повернуть повну URL-адресу, як і очікувалося. Однак цікаво відзначити, що метод підрядки є найшвидшим, особливо у Firefox.
1-е ОНОВЛЕННЯ: Насправді метод split (), запропонований Robusto, є кращим рішенням, ніж той, який я запропонував раніше, оскільки він буде працювати навіть тоді, коли рядків запитів немає:
var testURL = '/Products/List?SortDirection=dsc&Sort=price&Page=3&Page2=3';
testURL.split('?')[0]; // Returns: "/Products/List"
var testURL2 = '/Products/List';
testURL2.split('?')[0]; // Returns: "/Products/List"
Оригінальний відповідь:
var testURL = '/Products/List?SortDirection=dsc&Sort=price&Page=3&Page2=3';
testURL.substring(0, testURL.indexOf('?')); // Returns: "/Products/List"