Загрузить данные таблицы из текстового файла - PullRequest
0 голосов
/ 14 октября 2018

Данные моей таблицы хранятся в текстовом файле с именем test_array.txt

[
{id:1, name:"Oli Bob", age:"12", col:"red", dob:""},
{id:2, name:"Mary May", age:"1", col:"blue", dob:"14/05/1982"},
{id:3, name:"Christine Lobowski", age:"42", col:"green", dob:"22/05/1982"},
{id:4, name:"Brendon Philips", age:"125", col:"orange", dob:"01/08/1980"},
{id:5, name:"Margret Marmajuke", age:"16", col:"yellow", dob:"31/01/1999"},
]; 

Как мне вызвать текстовый файл, когда я устанавливаю данные.Я попробовал ниже, и структура таблицы является сборкой, но данные не загружаются, но в таблице указано ERROR.

       //load sample data into the table
    table.setData("../textfiles/test_array.txt");

В консоли браузера появляется следующее сообщение об ошибке.

Ошибка загрузки Ajax: SyntaxError: "JSON.parse: ожидаемое имя свойства или '}' в строке 2 столбца 2 данных JSON"

Вот весь мой скрипт

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="content-type" content="text/html; charset=iso-8859-1" />
<meta name="description" content="Johnson County Pharmacy Association, Johnson County, Iowa" />
<meta name="keywords" content="Johnson County Iowa Pharmacy Association pharmacist technician" />
<link href="../css/main.css" rel="stylesheet" />
<link href="../css/tabulator.css" rel="stylesheet" />
<link href="../css/tabulator.css.map" rel="stylesheet" />
<script type="text/javascript" src="../js/tabulator.js"></script>
<title>JCPA</title>
</head>

<body>
<div id="tblwrap">
<h2>Meeting Information Editor</h2>

    <div id="example-table"></div>

    <script>
        //create Tabulator on DOM element with id "example-table"
        var table = new Tabulator("#example-table", {
     	height:205, // set height of table (in CSS or here), this enables the Virtual DOM and improves render speed dramatically (can be any valid css height value)
     	layout:"fitDataFill",//fit columns to fit data and width of table (optional)
		//data:tableData, //set initial table data
     	columns:[ //Define Table Columns
    	 	{title:"Name", field:"name", width:150},
    	 	{title:"Age", field:"age", align:"left", formatter:"progress"},
    	 	{title:"Favourite Color", field:"col"},
    	 	{title:"Date Of Birth", field:"dob", sorter:"date", align:"center"},
     	],
     	rowClick:function(e, row){ //trigger an alert message when the row is clicked
     		alert("Row " + row.getData().id + " Clicked!!!!");
     	},
        });
      
        //load sample data into the table
    table.setData("../textfiles/test_array.txt");
    </script> 
</div>
</body>
</html>

Ответы [ 2 ]

0 голосов
/ 16 октября 2018

Я заставил его работать, используя двойные кавычки на клавишах

[
{"name":"Oli Bob", "age":"12", "col":"red", "dob":""},
{"name":"Mary May", "age":"1", "col":"blue", "dob":"14/05/1982"},
{"name":"Christine Lobowski", "age":"42", "col":"green", "dob":"22/05/1982"},
{"name":"Brendon Philips", "age":"125", "col":"orange", "dob":"01/08/1980"},
{"name":"Margret Marmajuke", "age":"16", "col":"yellow", "dob":"31/01/1999"}
]
0 голосов
/ 15 октября 2018

У вас недопустимая конечная запятая в строке 6 кода, строка с идентификатором 5 не должна иметь запятую в конце, и вам не нужна точка с запятой после массива, это недопустимый JSON.Это должно быть:

[
{id:1, name:"Oli Bob", age:"12", col:"red", dob:""},
{id:2, name:"Mary May", age:"1", col:"blue", dob:"14/05/1982"},
{id:3, name:"Christine Lobowski", age:"42", col:"green", dob:"22/05/1982"},
{id:4, name:"Brendon Philips", age:"125", col:"orange", dob:"01/08/1980"},
{id:5, name:"Margret Marmajuke", age:"16", col:"yellow", dob:"31/01/1999"}
]

Вы проверили в своем браузере инструменты разработчика сети, каков ответ?Также возможно, что ваш сервер не возвращает ожидаемый файл, проверка сетевых инструментов должна позволить вам подтвердить то, что возвращается

...