我有一个字符串,其中可能包含一个或多个YouTube或Vimeo定位符实例。我正在寻找一个搜索该字符串的javascript函数,检测锚href是youtube还是Viemo url,如果是,则将锚替换为带有href值的iframe。
注意:这是来自api而非dom元素的字符串。在将其发送到视图之前,我要进行此切换。
输入:
"check out this video! <a href="https://www.youtube.com/watch?v=STsWJ63QgCg&ab_channel=BonApp%C3%A9tit">https://www.youtube.com/watch?v=STsWJ63QgCg&ab_channel=BonApp%C3%A9tit</a>"
我想改为将锚改为iframe,这样您就可以播放视频,而无需转到链接。
所以像这样:
"check out this video! <iframe src=\"https://www.youtube.com/watch?v=STsWJ63QgCg&ab_channel=BonApp%C3%A9tit\" frameborder=\"0\" allowfullscreen=\"true\" allow=\"autoplay\"></iframe>";
香港专业教育学院尝试过正则表达式,但我不是那么擅长,我还没有找到任何好的例子。这基本上是我所拥有的:
function checkForVideoUrl(message) {
var youtubeCheck = "<a href=\"https://www.youtube.com/watch";
var vimeoCheck = "https://vimeo.com/";
if (message.toLowerCase().toString().indexOf(youtubeCheck) !== -1 || message.toLowerCase().toString().indexOf(vimeoCheck) !== -1) {
console.log('true');
// Replace anchors with video href's to iframes
}
}
使用正则表达式修改HTML并不是一种好习惯。使用可以将字符串解析为DOM结构并将其修改的库。当您使用jQuery标记问题时,可以在此实例中使用它。
以下示例查找a
字符串中的所有元素,并将其替换为,iframe
其src
设置为与原始相同的值href
。尝试这个:
var input = 'check out this video! <a href="https://www.youtube.com/watch?v=STsWJ63QgCg&ab_channel=BonApp%C3%A9tit">https://www.youtube.com/watch?v=STsWJ63QgCg&ab_channel=BonApp%C3%A9tit</a>';
let $input = $(`<div>${input}</div>`);
let $a = $input.find('a');
$a.replaceWith(i => `<iframe src="${$a.eq(i).prop('href')}" frameborder="0" allowfullscreen="true" allow="autoplay"></iframe>`);
console.log($input.html());
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句