我需要一些帮助来从短代码构建一个数组。 问题是匹配正则表达式部分。
我的短代码如下:
[email_image,id=1,c=member,fS=15,lH=20]
期望的输出:
{name: 'email_image', id: '1', c: 'member', fS: '15', lH: '20'}
如何更改我的功能(regex)
才能正常工作?
thanks.sepp。
function ajax(ed){
var str = tinyMCE.activeEditor.getContent();
var re = /\[email_image([^\]]*)\]/g;
var found = str.match(re);
found.map(function(item){
//console.log(item); // [email_image,id=1,c=member,fS=15,lH=20] ....
arraytophp = {name: 'email_image', id : item.split(',')[1].split('=')[1], c: item.split(',')[2].split('=')[1], fS : item.split(',')[3].split('=')[1], lH: item.split(',')[4].split('=')[1].replace(']','')};
// PROBLEM START *************************************************************
var arraytophp_test = {};
item.match(/([\w-]+)=([^,]+)/g).forEach(function(attribute) {
//console.log(attribute)
attribute = attribute.match(/([\w-]+)=(.+?)/);
arraytophp_test[attribute[1]] = attribute[2];
});
console.log(arraytophp_test);
// PROBLEM END **************************************************************
jQuery.ajax({
url: "StringImage_Ajax/ajaxImage",
type: "POST",
dataType: "json",
async:false,
data: {"data" : JSON.stringify(arraytophp)}
}).done(function(data){
string = data.string;
tinyMCE.activeEditor.setContent(tinyMCE.activeEditor.getContent().replace(item,string));
});
});
}
答案 0 :(得分:1)
而不是RegEx,基本的javascript可以做得很好。
当然RegEx很棒,但有时似乎用它来用大锤打碎鸡蛋。
var item = '[email_image,id=1,c=member,fS=15,lH=20]';
var result = item.slice(1, -1).split(',').
reduce(function (a,b) {
var v=b.split('=');if(v.length===1) a.name=v[0];
else a[v[0]]=v[1];return a}
,{});
console.log(result);
答案 1 :(得分:0)
<强>编辑:强>
我已经用这种方式修改了你的代码。
var arr = str.slice(1, -1).split(','), arraytophp_test = {};
$.each(arr, function(key, value){
if(value.indexOf('=') === -1){
arraytophp_test.name = value;
}else{
var k = value.split('=')[0];
var v = value.split('=')[1];
arraytophp_test[k] = v;
}
})
“str”是你的字符串......