0

テーブル文字列(csvなど)をhtmlテーブルに変換しようとしています。私のコードは単純なテーブルでは正常に動作しますが、行と列をマージすると失敗します。では、スクリプトで行スパンと列スパンを使用するにはどうすればよいですか?

<!DOCTYPE html>
<html ng-app="" ng-controller="myCtrl">
<style>
table, th, td {
border: 1px solid black;
padding:5px;
}
table {
   border-collapse: collapse;
   margin:10px;
}
</style>
<body>
<button ng-click="processData(allText)">
    Display CSV as Data Table
</button>
<div id="divID">
    <table>
        <tr ng-repeat="x in data">
            <td ng-repeat="y in x">{{ y }}</td>
        </tr>
    </table>
</div>
<div>
    <table>
    </table>
</div>

<script>
function myCtrl($scope, $http) {

$scope.allText=" |Through Air |Over Surface |\nRS(0)|in. CM(1)|mm CM(1)|in. CM(2)|mm CM(2)|\nB |3/32\n (a) CM(1)|2.4 \n (a) CM(1)|3/32 \n (a) CM(2)|2.4 \n (a) CM(2)|\nD |1/16\n (a) CM(1)|1.6 \n (a) CM(1)|1/8 \n (a) CM(2)|3.2 \n (a) CM(2)|\nLAST ROW";
$scope.processData = function(allText) {
    // split content based on new line
    var allTextLines = allText.split(/\|\n|\r\n/);
    var headers = allTextLines[0].split('|');
    var lines = [];

    for ( var i = 0; i < allTextLines.length; i++) {
        // split content based on comma
        var data = allTextLines[i].split('|');
        if (data.length == headers.length) {
            var temp = [];
            for ( var j = 0; j < headers.length; j++) {
                temp.push(data[j]);
            }
            lines.push(temp);
        }
    };
    $scope.data = lines;
};
}
</script>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.js"></script>
</body>
</html>

| | ---セルの区切り記号です

|\n --- 改行用

RS(#) ---行スパン wrt 列番号

CM(#) --- 列の分割 wrt 列ヘッダー

$scope.allText の値は CSV テーブル文字列です

したがって、基本的に、このテーブルを出力として取得する必要があります- 出力テーブル

4

1 に答える 1

1

関数で、processData表のセルを表すデータムをプロパティを持つオブジェクトにrowSpancolumnSplitます。

[[{value: 10, rowSpan: 1, columnSplit: 0}, ... ] ... ]

あなたの例にあるデータは、2 つの列にまたがるヘッダーを 1 つの「列」として定義しているように見え、他の列は実際には分割列であるため、問題があるようです。したがって、あなたの場合、すべてのrowSpanに1を追加する必要があると思います:

<td ng-repeat="y in x" rowSpan="{{y.rowSpan + 1 }}">{{ y.value }}</td>
于 2015-12-04T11:59:08.830 に答える