javascript - 将所有视频 anchor 实例替换为 iframe

标签 javascript jquery regex

我有一个字符串,其中可能包含一个或多个 YouTube 或 Vimeo anchor 实例。我正在寻找一个搜索此字符串的 javascript 函数,检测 anchor href 是 youtube 还是 Viemo url,如果是,则用具有 href 值的 iframe 替换 anchor 。

注意:这是一个来自 api 的字符串,而不是 dom 元素。在将其发送到 View 之前,我想进行此切换。

输入:

"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>"

主页 View : enter image description here

我想将该 anchor 更改为 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>

关于javascript - 将所有视频 anchor 实例替换为 iframe,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65109337/

相关文章:

jQuery 验证插件响应消息

javascript - 使用jquery输入后查找具有特定类的span

javascript - JavaScript 的命名空间架构

javascript - 正则表达式,如果捕获组匹配字符串

c# - RegEx 匹配一个模式,只要它前面没有不同的模式

javascript - Vue 3 Composition API 提供/注入(inject)在单个文件组件中不起作用

php - 无法从 Ajax 获取请求取回数据

javascript - 导航栏 mouseenter/mouseleave 在 li 元素之间不起作用

当字符串全是换行符时Java按换行符分割

javascript - 旋转图像而不重置旋转