Как анализировать текст, такой как XML, в объект JavaScript - PullRequest
0 голосов
/ 13 ноября 2011

Я создал функцию для этого.

var text="adsf [name]Victor[/name] dummytext [name]Elliot[/name] asdf [name]Jake[/name] asdf [foo]bar[/foo]";

alert( readTags(text,'name') ); //Victor,Elliot,Jake
alert( readTags(text,'foo') ); //bar

но теперь мне нравится реализовывать функцию, которая получает строку, подобную этой

[person]
    [name]jake[/name]
    [age]12[/age]
[/person]

и вернуть объект, подобный этому

var object={};
object['person']={};
object['name']='jake';
object['age']='12';
return(object);

но я не знаю, как перебрать текст. Как бороться с начальными и конечными тегами? как

[tag] [tag]value[/tag] [/tag]

Я подумал найти начальный тег слева и конечный тег справа, используя indexOf('[tag]') и lastindexOf('[/tag]')

но в этой ситуации не работает

[tag]value[/tag] [tag]value[/tag]

это предыдущая функция

function readTags(str,property){

    var beginTag='['+property+']';
    var endTag='[/'+property+']';

    var values=new Array(0);

    while(str.indexOf(beginTag)!=-1){
        values[values.length]=strBetween(str,beginTag,endTag);
        str=str.substring(str.indexOf(endTag)+endTag.length);
    }
    return(values);
}

function strBetween(string,strBegin,strEnd){    //StrBetween("abcdef","b","e")  //return "cd"

    var posBegin, posEnd;

    posBegin=string.indexOf(strBegin);
    string=string.substring(posBegin + strBegin.length);
    posEnd=string.indexOf(strEnd);
    string=string.substring(0,posEnd);

    if ((posBegin==-1)||(posEnd==-1)){
        return(null);
    }else{
        return(string);
    }
}

Ответы [ 3 ]

4 голосов
/ 13 ноября 2011

Если у вас нет веской причины , а не , чтобы использовать JSON , не делайте этого.JSON отлично справляется со всеми этими проблемами и может быть легко перенесен с сервера на клиент и наоборот.

Но так как это кажется забавным, я постараюсь посмотреть, смогу ли я найти ответ.


Поскольку ваша структура напоминает XML, просто замените скобки на < и > и проанализируйте его как XML:

text = text.replace('[', '<').replace(']', '>');

if (typeof DOMParser != "undefined") {
  var parser = new DOMParser();
  var xml = parser.parseFromString(text, 'text/xml');
} else {
  var xml = new ActiveXObject('Microsoft.XMLDOM');
  xml.async = 'false';
  xml.loadXML(text); 
}

Теперь xml содержит DOMDocumentчто вы можете разобрать:

xml.getElementsByTagName('person').childnodes;

Попробуйте этот возможно работающий код (не тестировал):

function createObject(element) {
  var object = {};

  if (element.childNodes.length > 0) {
    for (child in element.childnodes) {
      object[element.tagName] = createObject(child);
    }

    return object;
  } else {
    return element.nodeValue;
  }
}
1 голос
/ 13 ноября 2011

Я подумал, что было бы интересно обойтись без стороннего парсера, поэтому я построил мне простой:

function parse(code)
{
  var obj = {},
      cur = obj,
      stack = [];

  code.replace(/\[([^\]]+)\]|([^\[]*)/g, function (match, tagName, text) {
    if (tagName)
    {
      if (tagName.charAt(0) == "/")
      {
        /* end tag */
        cur = stack.pop();
      }
      else
      {
        /* start tag */
        stack.push(cur);
        cur = cur[tagName] = {};
      }
    }
    else
    {
      cur["#text"] = text;
    }
  });

  return obj;
}

var obj = parse(text);
0 голосов
/ 09 декабря 2011
...