将视频锚点的所有实例替换为iframe

swedish_junior_dev

我有一个字符串,其中可能包含一个或多个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
}

}

罗里·麦克罗森(Rory McCrossan)

使用正则表达式修改HTML并不是一种好习惯。使用可以将字符串解析为DOM结构并将其修改的库。当您使用jQuery标记问题时,可以在此实例中使用它。

以下示例查找a字符串中的所有元素,并将其替换为,iframesrc设置为与原始相同的值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] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

将所有点替换为单个

如何在ColdFusion中使用正则表达式将所有锚标签替换为不同的锚

WordPress将所有[vc_single_image]短代码实例替换为img src

将特定短语的所有实例替换为用户定义的macOS

将所有变量替换为整数

将所有“字符替换为\” Java

使用JQuery从页面上的所有链接中获取锚点参数并替换目标链接的href

将锚点转换为按钮

Javascript:将整个锚替换为文本

将所有A替换为B,然后将所有B替换为A

将所有逗号分隔的数字替换为JavaScript中字符串中的点分隔数字

将一个文件中的所有字符串实例替换为另一个文件

将引导程序类应用于角度组件中的所有子锚点

将所有锚点移动到浮动图像顶部的 Word VBA 宏

将所有与格式dd / mm / yyyy匹配的锚文本转换为mm / yyyy

将 NA 替换为 0,将所有其他值/文本替换为 1

将所有链接与空锚匹配?

正则表达式选择除某些锚点之外的所有锚点

JAVASCRIPT:将iframe替换为新的iframe,或者将iframe替换为不存在的iframe

将所有相对URL替换为绝对URL

Python:将所有列替换为reg的输出

将所有英文报价替换为德国报价

如何将所有/替换为-从字符串

将div中的所有链接替换为帖子

Vim:将所有以string开头的行替换为line

SelectionSort算法将所有元素替换为零

将所有<br>标签替换为javascript中的空格

宏,将所有对printf的调用全部替换为空

将行的所有值替换为行的频繁值