javascript - 从 Alloy UI 数据表创建 JSON

标签 javascript html json yui3 alloy-ui

我已经使用 AlloyUI 从 JSON 创建了一个数据表,每次单击“添加行”按钮时我都会推送一个新行。完成所有这些后,我需要在单击“提交”时创建最终数据集合的 json。但我无法找到一种使用 AlloyUI 将数据表/HTML 表(任一都可以)转换为 JSON 的方法

这是我的 html 和 js:

YUI().use('aui-datatable','json-stringify', function(A) {
 
	var data = [
	            {Name: 'Bob', Age: '28',Salary: '10000',Department: 'Admin',Address: 'Kolkata'},
	            {Name: 'Joe', Age: '42',Salary: '20000',Department: 'Accounts',Address: 'Kolkata'},
	            {Name: 'Sarah', Age: '35',Salary: '30000',Department: 'Sales',Address: 'Kolkata'},
	            {Name: 'Billy', Age: '24',Salary: '40000',Department: 'Admin',Address: 'Kolkata'},
	            {Name: 'James', Age: '36',Salary: '50000',Department: 'Accounts',Address: 'Kolkata'},
	            {Name: 'Stark', Age: '51',Salary: '60000',Department: 'Sales',Address: 'Kolkata'}
	          ];
 
	var dtable = new A.DataTable.Base({
		columnset: ['Name', 'Age','Salary','Department','Address'],
		recordset: data
	})
	.render("#container");
	
	
	A.one('#addRow').on('click', function() {
		data.push({
			"Name": A.one('#Name').get('value'),
    		"Age": A.one('#Age').get('value'),
    		"Salary": A.one('#Salary').get('value'),
    		"Department": A.one('#Department').get('value'),
    		"Address": A.one('#Address').get('value')
		});
		dtable.set('recordset', data);
		A.one('#Name').set('value', '');
		A.one('#Age').set('value', '');
		A.one('#Salary').set('value', '');
		A.one('#Department').set('value', '');
		A.one('#Address').set('value', '');
		
	});
	A.one('#submit').on('click', function() {
    //Here I need the code to create JSON  
    });
});
<script src="http://cdn.alloyui.com/2.0.0/aui/aui-min.js"></script>
<link href="http://cdn.alloyui.com/2.0.0/aui-css/css/bootstrap.min.css" rel="stylesheet"></link>
<div class="example">
  <div>
    <input id="Name" style="width:90px" placeholder="Name"></input>
    <input id="Age" style="width:30px" placeholder="Age"></input>
    <input id="Salary" style="width:60px" placeholder="Salary"></input>
    <input id="Department" style="width:90px" placeholder="Department"></input>
    <input id="Address" style="width:100px" placeholder="Address"></input>
  </div>
  <br>
  <div id="container"></div>
  <br>
  <button id="addRow">Add row</button>
  <button id="submit">Submit</button>
</div>

最佳答案

您需要使用JSON.stringify() 。将您想要发送到 JSON 的数据传递给它。对于您的示例,您应该传递 dtable.get('recordset'):

A.JSON.stringify(dtable.get('recordset'))

这是使用您的代码的可运行示例:

YUI().use('aui-datatable','json-stringify', function(A) {
 
	var data = [
	            {Name: 'Bob', Age: '28',Salary: '10000',Department: 'Admin',Address: 'Kolkata'},
	            {Name: 'Joe', Age: '42',Salary: '20000',Department: 'Accounts',Address: 'Kolkata'},
	            {Name: 'Sarah', Age: '35',Salary: '30000',Department: 'Sales',Address: 'Kolkata'},
	            {Name: 'Billy', Age: '24',Salary: '40000',Department: 'Admin',Address: 'Kolkata'},
	            {Name: 'James', Age: '36',Salary: '50000',Department: 'Accounts',Address: 'Kolkata'},
	            {Name: 'Stark', Age: '51',Salary: '60000',Department: 'Sales',Address: 'Kolkata'}
	          ];
 
	var dtable = new A.DataTable.Base({
		columnset: ['Name', 'Age','Salary','Department','Address'],
		recordset: data
	})
	.render("#container");
	
	
	A.one('#addRow').on('click', function() {
		data.push({
			"Name": A.one('#Name').get('value'),
    		"Age": A.one('#Age').get('value'),
    		"Salary": A.one('#Salary').get('value'),
    		"Department": A.one('#Department').get('value'),
    		"Address": A.one('#Address').get('value')
		});
		dtable.set('recordset', data);
		A.one('#Name').set('value', '');
		A.one('#Age').set('value', '');
		A.one('#Salary').set('value', '');
		A.one('#Department').set('value', '');
		A.one('#Address').set('value', '');
		
	});
	A.one('#submit').on('click', function() {
      A.one('#json').set('innerHTML', A.JSON.stringify(dtable.get('recordset')));
    });
});
<script src="https://cdn.rawgit.com/stiemannkj1/701826667a70997013605edcd37e92a6/raw/469fe1ae297e72a5a80eb9015003b7b04eac735e/alloy-ui-3.0.1_aui_aui-min.js"></script>
    <link href="https://cdn.rawgit.com/stiemannkj1/90be22de7f48c729b443af14796d91d3/raw/a9f35ceedfac7fc0559b121bed105eaf80f10bf2/aui-css_css_bootstrap.min.css" rel="stylesheet"></link>
<div class="example">
  <div>
    <input id="Name" style="width:90px" placeholder="Name"></input>
    <input id="Age" style="width:30px" placeholder="Age"></input>
    <input id="Salary" style="width:60px" placeholder="Salary"></input>
    <input id="Department" style="width:90px" placeholder="Department"></input>
    <input id="Address" style="width:100px" placeholder="Address"></input>
  </div>
  <br>
  <div id="container"></div>
  <br>
  <button id="addRow">Add row</button>
  <button id="submit">Submit</button>
</div>

<div id="json"></div>

关于javascript - 从 Alloy UI 数据表创建 JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30235666/

相关文章:

javascript - 在 div 上使用可调整大小的函数将另一个分区移动到下一行

javascript - 计算 d3.js 中的数据项

javascript - 如何从 Facebook javascript SDK 获取授权码

javascript - 使用 ajax 的 Select2 使用 Rails turbolinks 事件进行了多次初始化

python - 如何将文本文件的内容顺序保存为json格式的列表(不是串联)

javascript - 如何在 URL 中请求不带 'callback' 的 jsonp

javascript - 带有移动平均线的 HTML5/JS 图表

html - CSS 列表问题

javascript - 如何在经典 ASP 中显示有关下拉框值的工具提示?

php - Swift httppost 数据未插入到 MySQL 数据库