2012-12-28 59 views
0

在这段代码中,我带入一个没有结构化的字符串,并将其解析为一个JS对象。我现在需要将其应用于Web表单。复杂的JS对象填充可点击的列表和表格

Here is the demo。它显示Parsed/Structured对象层次结构并警告一个目标项目的示例。

  1. 创建关键项目(即按钮,图像,标签等

  2. 点击列表项的可点击列表,填充形式与价值

  3. 修改的值并保存回对象

有一些注意事项:

  1. 有重复键。我不知道如何让他们独一无二,同时保持数据的完整性。我无法嵌套它们。我唯一能想到的就是给它们添加一个唯一的ID
  2. 理想情况下,表单将根据对象中的字段动态生成字段。 (即“按钮”具有宽度,高度,过渡和名称,其中'标签'具有不同的字段集合
  3. 某些元素是嵌套的(即“滚动”有它自己的'按钮'和'标签“

任何帮助,将不胜感激。下面的代码并创建元素的列表,但我不能让它根据我点击值加载到一种形式。

这里是代码

//Parse String 
var str = 'View\n{\n Name: View1;\n Image\n {\n  BackgroundImage: Image.gif;\n  Position: 0, 0;\n  Width: 320;\n  Height: 480;\n }\n\n Button\n {\n  BackgroundImage: Button.gif;\n  Transition: View2;\n  Position: 49, 80;\n  Width: 216;\n  Height: 71;\n }\n\n Button\n {\n  BackgroundImage: Button2.gif;\n  Position: 65, 217;\n  Width: 188;\n  Height: 134;\n }\n\n Label\n {\n  Position: 106, 91;\n  Width: 96;\n  Height: 34;\n  Text: "Button";\n  FontSize: 32;\n  Color: 0.12549, 0.298039, 0.364706, 1;\n }\n Scroll\n {\n  Position: 106, 91;\n  Width: 96;\n  Height: 34;\n  Button{\n   BackgroundImage: Button2.gif;\n   Position: 65, 217;\n   Width: 188;\n   Height: 134;\n  }\n  Button{\n   BackgroundImage: Button2.gif;\n   Position: 65, 217;\n   Width: 188;\n  \n  Height: 134;\n  }\n\n }\n\n}'; 

str = str.replace(/(\w+)\s*\{/g, "$1:{"); // add in colon after each named object 
str = str.replace(/\}(\s*\w)/g, "},$1"); // add comma before each new named object 
str = str.replace(/;/g, ","); // swap out semicolons with commas 
str = str.replace(/,(\s+\})/g, "$1"); // get rid of trailing commas 
str = str.replace(/([\d\.]+(, [\d\.]+)+)/g, "[$1]"); // create number arrays 
str = str.replace(/"/g, ""); // get rid of all double quotes 
str = str.replace(/:\s+([^\[\d\{][^,]+)/g, ':"$1"'); // create strings 

$("#parseList").html(str); 

var objStr; 
eval("objStr={" + str + "};"); 

//console.log(objStr.View.Button) 
//alert(objStr.View.Scroll.Button.Width); 
//End Parse String 

$(document).ready(function() { 

    //Build Initial Object LIst 
    var initObjectList = '<div id="prePop">'; 
    $.each(objStr.View, function (k, v) { 
     initObjectList += '<div class="inLineObjects">' + '<div class="key">' + k + '</div>' + '</div>'; 

    }); 
    initObjectList += '</div>'; 
    $('#code').append(initObjectList) 

对象输出示例:

View:{ 
    Name:"View1", 
    Image:{ 
     BackgroundImage:"Image.gif", 
     Position: [0, 0], 
     Width: 320, 
     Height: 480 
    }, 

    Button:{ 
     BackgroundImage:"Button.gif", 
     Transition:"View2", 
     Position: [49, 80], 
     Width: 216, 
     Height: 71 
    }, 

    Button:{ 
     BackgroundImage:"Button2.gif", 
     Position: [65, 217], 
     Width: 188, 
     Height: 134 
    }, 

    Label:{ 
     Position: [106, 91], 
     Width: 96, 
     Height: 34, 
     Text:"Button", 
     FontSize: 32, 
     Color: [0.12549, 0.298039, 0.364706, 1] 
    }, 
    Scroll:{ 
     Position: [106, 91], 
     Width: 96, 
     Height: 34, 
     Button:{ 
      BackgroundImage:"Button2.gif", 
      Position: [65, 217], 
      Width: 188, 
      Height: 134 
     }, 
     Button:{ 
      BackgroundImage:"Button2.gif", 
      Position: [65, 217], 
      Width: 188, 

     Height: 134 
     } 

    } 

} 
+1

哎呀,使用'JSON'对象的'parse'方法来解析的是,没有必要用你自己的工作了正则表达式。 – Austin

+0

这里真正的问题是什么?一般来说,如果您尽可能具体地提出问题,而不是包含大量内容并说“任何帮助将不胜感激”,您将在Stack Overflow上得到更好的响应。我们喜欢在这里给予帮助,你不需要问;-)但是你确实需要(或者至少你会得到更好的答案,如果你的话)让我们尽可能简单地帮助你。 – machineghost

+0

你无法控制这个输出吗?如果服务器将向您发送json,则需要以正确的格式向您发送_valid_ json(重复键在JSON规范中无效)。或者,也许我在这里错过了一些东西,是什么样的特定格式(CSS)的输入? – Austin

回答

0

如果我理解正确的话,可能是你最好的选择是建立一种形式为每个objStr.View,为您打造它,但保持这种形式隐藏(CSS display:none)。然后,当用户点击一个,你所要做的就是$(thatForm).show(),你就被设置了。

+0

我很害怕这个。必须围绕这些数据维护一组表单。我试图创建一个循环遍历该对象并为这些字段创建输入的表单。 – Rob

+0

您绝对仍然可以这样做:当您构建表单时,不是直接构建表单,而是根据选项创建一个函数,然后调用该函数。这样你只有一点代码可以为每个对象生成表单,但是你可以为每个对象准备好一个单独的表单并等待你隐藏在页面上。 – machineghost

+0

对不起。我以前没有这样做过。你能为我指出正确的方向吗?我的列表代码是否足够用于该部分?如何根据我的选择填充动态表单?下面的一切//建立初始对象LIst – Rob

0

解决方案:http://jsfiddle.net/kHysL/

这里是我的解决方案:

var str = 'View\n{\n Name: View1;\n Image\n {\n  BackgroundImage: Image.gif;\n  Position: 0, 0;\n  Width: 320;\n  Height: 480;\n }\n\n Button\n {\n  BackgroundImage: Button.gif;\n  Transition: View2;\n  Position: 49, 80;\n  Width: 216;\n  Height: 71;\n }\n\n Button\n {\n  BackgroundImage: Button2.gif;\n  Position: 65, 217;\n  Width: 188;\n  Height: 134;\n }\n\n Label\n {\n  Position: 106, 91;\n  Width: 96;\n  Height: 34;\n  Text: "Button";\n  FontSize: 32;\n  Color: 0.12549, 0.298039, 0.364706, 1;\n }\n Scroll\n {\n  Position: 106, 91;\n  Width: 96;\n  Height: 34;\n  Button{\n   BackgroundImage: Button2.gif;\n   Position: 65, 217;\n   Width: 188;\n   Height: 134;\n  }\n  Button{\n   BackgroundImage: Button2.gif;\n   Position: 65, 217;\n   Width: 188;\n  \n  Height: 134;\n  }\n\n }\n\n}'; 

str = str.replace(/(\w+)\s*\{/g, "$1:{"); // add in colon after each named object 
str = str.replace(/\}(\s*\w)/g, "},$1"); // add comma before each new named object 
str = str.replace(/;/g, ","); // swap out semicolons with commas 
str = str.replace(/,(\s+\})/g, "$1"); // get rid of trailing commas 
str = str.replace(/([\d\.]+(, [\d\.]+)+)/g, "[$1]"); // create number arrays 
str = str.replace(/"/g, ""); // get rid of all double quotes 
str = str.replace(/:\s+([^\[\d\{][^,]+)/g, ':"$1"'); // create strings 

$("#parseList").html(str); 

var objStr; 
eval("objStr={" + str + "};"); 

//End Parse String 

$(document).ready(function() { 
    var selected; 
    //Build Initial Object LIst 
    var initObjectList = '<div id="main">'; 
    $.each(objStr.View, function (k, v) { 
     initObjectList += '<div>' + k + '</div>'; 

    }); 
    initObjectList += '</div>'; 
    $('#main').append(initObjectList) 

    $(document).on('click', '#main div div', function() { 
     var index = $('#main div div').index(this); 

     $(this).click(function() { 
      $('#form div').remove(); 
      codeSnippet = ""; 
      x = $('#main div div').toArray(); 
      codeSnippet = (x[index].innerHTML); 
      console.log(codeSnippet); 

      var initObjectDetail = '<div id="form">'; 
      $.each(objStr.View[codeSnippet], function (k, v) { 
       initObjectDetail += '<div>' + k + '</div>' + '<input value=' + v + '>' + '</input>'; 
       console.log(v); 

      }); 
      initObjectList += '</div>'; 
      $('#form').append(initObjectDetail) 
     }); 

    }); 
});​