首页  >  问答  >  正文

javascript - table td单元格生成tr问题

假设现在有10个td的json对象,td的colspan属性值取1-3, 现在要把它们变成td放到tr中. td的colspan为1时,tr里放3个td,colspan为2时,tr里放两个td.colspan为3时,tr里放3个td. 怎么做到?

漂亮男人漂亮男人2712 天前561

全部回复(2)我来回复

  • PHPz

    PHPz2017-05-16 13:46:37

    <tr ng-if="$scope.colspan === 1">
        <td></td>
        <td></td>
        <td></td>
    </tr>
    <tr ng-if="$scope.colspan === 2">
        <td></td>
        <td></td>
    </tr>
    <tr ng-if="$scope.colspan === 3">
        <td></td>
        <td></td>
        <td></td>
    </tr>

    用angular>ng-if解决

    回复
    0
  • 仅有的幸福

    仅有的幸福2017-05-16 13:46:37

    随便猜了下你的想法。。

    var json = [{
        colspan: 1,
        title: 1
    }, {
        colspan: 2,
        title: 2
    }, {
        colspan: 3,
        title: 3
    }]
    
    document.body.innerHTML = '<table>'+ generateTr(json) +'</table>'
    
    function generateTr(json) {
        var tr = []
        for (var i = 0, l = json.length; i < l; i++) {
            var item = json[i],
                tds = []
            for (var j = 0, k = Math.ceil(3 / item.colspan); j < k; j++) {
                tds.push('<td' + (j == 0 ? ' colspan="' + item.colspan+'"' : '') + '>' + item.title + '</td>')
            }
            tr.push('<tr>' + tds.join('') + '</tr>')
        }
        return tr.join('')
    }
    

    回复
    0
  • 取消回复