Reputation: 11126
this is the code I am trying :
var arr = [];
var str = "hey check this video out! youtube.com/watch?v=123456 and there is some other text youtube.com/watch?v=3t_3456 and some more.";
while (match = /youtube\.com\/watch\?v=([^\s]+)/.exec(str)) {
arr.push(match[1]);
}
console.log(arr);
it should capture the last part of the url's and push them to an array.
the array I am expecting is :
["123456", "3t_3456"]
but this code is going in an infinite loop, what's wrong with it ?
Upvotes: 2
Views: 3754
Reputation: 101758
The difference between your code and the page you linked to is:
g
(global) flag, so even if you were not creating new regexes, it would just keep finding the first match.You need to reuse the same regex, and use the g
flag:
var pattern = /youtube\.com\/watch\?v=([^\s]+)/g;
while (match = pattern.exec(str)) {
arr.push(match[1]);
}
Upvotes: 7
Reputation: 123658
You are inviting an infinite loop without using the global flag in your regex.
var arr = [];
var str = "hey check this video out! youtube.com/watch?v=123456 and there is some other text youtube.com/watch?v=3t_3456 and some more.";
var re = /youtube\.com\/watch\?v=([^\s]+)/g;
while (match = re.exec(str)) {
arr.push(match[1]);
}
console.log(arr);
See a working example here.
Without the g
flag you'd run into an infinite loop, see here (WARNING: Clicking this link may crash your browser.).
Upvotes: 2