利用正则给所有的 video audio的 src属性修改资源地址


let html = `<div class="video-container">
        <div>视频</div>
        <video src="/video没有前缀的地址.mp4" autoplay width="300" height="300"></video>
    </div>
    <div class="audio-container">
        <div>音频</div>
        <audio id="audio" src="/audio没有前缀的地址.mp3" controls ></audio>
    </div>`


        function addHost(html, host) {
            let reg = /<(video|audio).*?src="(.*?)".*?>.*?<\/(video|audio)>/g;
            let result = html.match(reg);
            if (result) {
                for (let i = 0; i < result.length; i++) {
                    let videoUrl = result[i].match(/src="(.*?)"/)[1];
                    const video = result[i].replace(videoUrl, `${host + videoUrl}`)
                    html = html.replace(result[i], video);
                }
            }
            return html
        }

        console.log(addHost(html, '假装是前缀'));
        // 结果
        //  <div class="video-container">
        //     <div>视频</div>
        //     <video src="假装是前缀/video没有前缀的地址.mp4" autoplay width="300" height="300"></video>
        // </div>
        // <div class="audio-container">
        //     <div>音频</div>
        //     <audio id="audio" src="假装是前缀/audio没有前缀的地址.mp3" controls></audio>
        // </div> 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
正则匹配所有图片地址src的方法可以使用以下几种方式: 1. 使用JavaScript正则表达式进行匹配。可以使用以下代码: ```javascript var str = "this is test string <img src=\"http:yanue.net/test.jpg\" width='50' > 123 and the end <img src=\"所有地址也能匹配.jpg\" /> 33! <img src=\"/uploads/attached/image/20120426/20120426225658_92565.png\" alt=\"\" />"; var imgReg = /<img.*?(?:>|\/>)/gi; var srcReg = /src=\[\'\"\]?(\[^\'\"\]*)\[\'\"\]?/i; var arr = str.match(imgReg); var imgSrcArr = \[\]; for (var i = 0; i < arr.length; i++) { var src = arr\[i\].match(srcReg); if (src && src\[1\]) { imgSrcArr.push(src\[1\]); } } console.log(imgSrcArr); ``` 这段代码会将字符串中所有的图片地址(src属性)提取出来并存储在imgSrcArr数组中。 2. 使用JavaScript正则表达式进行匹配。可以使用以下代码: ```javascript let matchReg = /<img.*?(?:>|\/>)/gi; let srcReg = /src=\[\'\"\]?(\[^\'\"\]*)\[\'\"\]?/i; let str = this.form.content; let arr2 = str.match(matchReg); let imgSrcArr = \[\]; if (arr2 != null) { for (let i = 0; i < arr2.length; i++) { let src = arr2\[i\].match(srcReg); if (src && src\[1\]) { imgSrcArr.push(src\[1\]); } } } console.log(imgSrcArr); ``` 这段代码会将字符串中所有的图片地址(src属性)提取出来并存储在imgSrcArr数组中。 3. 使用PHP的正则表达式进行匹配。可以使用以下代码: ```php $str = '<img src="/zentao/file-read-92254.jpg" alt="" />'; $pattern_imgTag = '/<img\b.*?(?:\>|\/>)/i'; $pattern_src = '/\bsrc\b\s*=\s*\[\'\"\]?(\[^\'\"\]*)\[\'\"\]?/i'; preg_match_all($pattern_imgTag, $str, $matchIMG); $imgSrcArr = \[\]; if (isset($matchIMG\[0\])) { foreach ($matchIMG\[0\] as $key => $imgTag) { preg_match_all($pattern_src, $imgTag, $matchSrc); if (isset($matchSrc\[1\])) { foreach ($matchSrc\[1\] as $src) { $imgSrcArr\[\] = $src; } } } } var_dump($imgSrcArr); ``` 这段代码会将字符串中所有的图片地址(src属性)提取出来并存储在$imgSrcArr数组中。 以上是三种常用的正则匹配图片地址(src属性)的方法,你可以根据自己的需求选择其中一种来使用。 #### 引用[.reference_title] - *1* [JavaScript正则匹配出所有图片及所有图片地址src](https://blog.csdn.net/qq_43434300/article/details/102676481)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [js正则表达式匹配到所有img图片和src](https://blog.csdn.net/qq_43777572/article/details/127406840)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [正则匹配img中的src/a标签href](https://blog.csdn.net/phpstory/article/details/126409163)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值