图片可能会出现图片的宽度超过屏幕宽度
需要改变图片的宽度,
把图片的宽过滤成width:100%就行
var richtext =JSON.stringify(res.data.data.noticeContent)
richtext= richtext.replace(/\width:.*?\px/g, `width: 100%`)
this.ArticleContent = JSON.parse(richtext)
注意从后台获取数据格式的转换
var a='<div><a><img src="file:///c:/ssd/ads.jpg"></a></div>'
while (/(file\:\/\/\/[^\/]*)\/(.*\")/.test(a))
a = a.replace(/(file\:\/\/\/[^\/]*)\/(.*\")/, "$1\\$2")
这样可以替换file:///开头,以"结尾的字符串中的所有/符号了,由于要匹配file:///开头,以"结尾, 正则中必须在开始加上file\:\/\/\/ 结尾加上\".而加上了这,replace方法的时候就算正则加上g,也是只替换一次了.所以加个WHILE循环.就可以全部替换了.不过正则还不能定义为变量.定义了变量,下面用变量的话,还是只替换一次,这我也不清楚是为什么了,可能跟Js中正则表达式对象的某些属性有关吧.
不太懂Js,就学了四天...
这种情况最好把中间这串拿出来 替换好再放回去 如下
var a='<div><a><img src="file:///c:/ssd/ads.jpg"></a></div>'
var re = /file\:\/\/\/.*\"/
var b = re.exec(a)[0] //拿到整个字符串中以file:///开头,以"结尾的字符串
b = b.replace(/\//g, "\\") //把拿到的字符串中的/全部替换成\
b = b.replace(/file\:\\\\\\/, "file:///")
a = a.replace(re, b)
第一种的那个没问题的.第二个仔细看了下,是我大意了,加上一句 b = b.replace(/file\:\\\\\\/, "file:///")就好了,不过感觉比第一种麻烦了.用第一种的那个就好了
比如判断abcdefg是否以abcd开头:
var fdStart = str.indexOf('abcd')
if(fdStart === 0) {
str以abcd开头
} else if (fdStart === -1) {
str不是以abcd开头
} else {
str包含abcd
}