博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
删除内容同时删除富本编辑器上传的图片文件
阅读量:6138 次
发布时间:2019-06-21

本文共 1629 字,大约阅读时间需要 5 分钟。

思路核心:

查找当前文章所有富本上传的图片路径,组成数组(正则匹配)。

1、查找图片路径组成数组

//校验通过执行查找图片路径,删除      let imgReg = /
|\/>)/gi; //匹配src属性 let srcReg = /src=[\'\"]?([^\'\"]*)[\'\"]?/i; let arr = ideas.details.match(imgReg); let newArr = [] // alert('所有已成功匹配图片的数组:'+arr); arr.forEach(v=>{ let src = v.match(srcReg); //获取图片地址 if(src[1]){ //alert('已匹配的图片地址'+(i+1)+':'+src[1]); if(src[1].indexOf("http://")!=-1||src[1].indexOf("https://")!=-1)// !=-1含有 ==-1不含有 { }else{ newArr.push(src[1]) } } })复制代码

2、逻辑是先删除文章,成功后删图片,最后封装成公共模块方便调用

/** * @ 查找内容 图片 路径 返回数组 * @ 参数 X 表示 内容,返回 图片数组 */exports.searchImgUrl=function(x){    //校验通过执行查找图片路径,删除    let imgReg = /
|\/>)/gi; //匹配src属性 let srcReg = /src=[\'\"]?([^\'\"]*)[\'\"]?/i; let arr = x.match(imgReg); let newArr = [] // alert('所有已成功匹配图片的数组:'+arr); arr.forEach(v=>{ let src = v.match(srcReg); //获取图片地址 if(src[1]){ //alert('已匹配的图片地址'+(i+1)+':'+src[1]); if(src[1].indexOf("http://")!=-1||src[1].indexOf("https://")!=-1)// !=-1含有 ==-1不含有 { }else{ newArr.push(src[1]) } } }) return newArr}复制代码

最后 调用

const pubFun = require('../../config/public');      let newArr = pubFun.searchImgUrl(ideas.details)      newArr.forEach(v=>{        console.log(v)        fs.unlink(path.normalize(__dirname+'/../../public' +v), function(err) {          if (err) {            return console.error(err);          }          console.log("文件删除成功!");        });      })复制代码

转载地址:http://imrua.baihongyu.com/

你可能感兴趣的文章
Sentinel 1.5.0 正式发布,引入 Reactive 支持
查看>>
如何对网站进行归档
查看>>
数据库之MySQL
查看>>
2019/1/15 批量删除数据库相关数据
查看>>
数据类型的一些方法
查看>>
Mindjet MindManager 2019使用教程:
查看>>
游戏设计的基本构成要素有哪些?
查看>>
详解 CSS 绝对定位
查看>>
AOP
查看>>
我的友情链接
查看>>
NGUI Label Color Code
查看>>
.NET Core微服务之基于Polly+AspectCore实现熔断与降级机制
查看>>
vue组件开发练习--焦点图切换
查看>>
浅谈OSI七层模型
查看>>
Webpack 2 中一些常见的优化措施
查看>>
移动端响应式
查看>>
python实现牛顿法求解求解最小值(包括拟牛顿法)【最优化课程笔记】
查看>>
js中var、let、const的区别
查看>>
腾讯云加入LoRa联盟成为发起成员,加速推动物联网到智联网的进化
查看>>
从Python2到Python3:超百万行代码迁移实践
查看>>