特殊正则
密码
1、同时存在大小写、数字,长度大于六位
/^(?=.\d)(?=.[a-z])(?=.*[A-Z])[a-zA-Z\d]{7,100}$/
2、同时存在大小写、数字,或者包含特殊字符(._~!@#$^&*),禁止空格,长度大于六位
/^(?!.\s)(?=.\d)(?=.[a-z])(?=.[A-Z])[a-zA-Z\d |a-zA-Z\d._~!@#KaTeX parse error: Expected group after '^' at position 1: ^̲&*]{7,100}/
过滤html标签
/<[^>]+>/g
使用场景:针对title属性中的html标签过滤
1、使用filter和map过滤
function ts(data){
if (data && typeof data === 'string' && /<[^>]+>/g.test(data)) {
if (data.replace(/<[^>]+>/g, '').indexOf('\n') !== -1) { // 去掉多行以及空格
return data.replace(/<[^>]+>/g, '').split('\n').filter(x => x.trim()).map(x => x.trim()).join('\n')
} else {
return data.replace(/<[^>]+>/g, '')
}
}
}
console.log(ts(`
<div class="sd">
<span> A: 0 </span>
<span> B: 0 </span>
<span> C: 0 </span>
</div>`))
//'A: 0\nB: 0\nC: 0'
2、使用reduce过滤
return data.replace(/<[^>]+>/g, '').split('\n').reduce((obj, item) => {
if (item.trim()) obj.push(item.trim())
return obj
}, []).join('\n')
//或者换成这种
//return data.replace(/<[^>]+>/g, '').split('\n').reduce((obj, item) => { if (item.trim()) { obj += item.trim() + '\n' } return