Angular中的ngRepeat使用心得

前段时间在实际项目中遇到一个问题,前端通过Ajax获取到一段数据,其中包括一段整形数字,这个数字表示一个动态的业务值,而这个值是由客户决定的。

OK,问题来了,我现在要使用ngRepeat来循环这个值,比如,客户设置了10,那么我就要循环10次,如果是12,就循环12次,咋一眼看上去并不难,但是如何用ngRepeat来循环呢?

我们都知道,ngRepeat是循环一个数组或对象,比如像下面这样

<tr ne-repeat='t in ["a", "b", "c"]'>
  //....
</tr>

但是如果只给你一个值,如何弄呢?这个,我使用了过滤器来解决这个问题

具体看代码:

过滤器代码:

app.filter('range', function () {
    return function (total, input, step) {
            //定义步长
            var _step = (angular.isDefined(step) && angular.isNumber(step)) ? step : 1;

            if (angular.isNumber(input)) {
                var _input = parseInt(input);
                //如果步长为1
                if (_step == 1) {
                    for (var i = 0; i < _input; i++) {
                        total.push(i+1);
                    }
                }
                //如果大于1
                if (_step > 1) {
                    for (var i = 0; i < _input; i += _step) {
                        total.push(i+1);
                    }
                }

            }
            return total;
        }
})

HTML中则是这样:

<tr ng-repeat="n in [] | toRange : resultsData.tableNum">

resultsData.tableNum就是我们拿到了数值,通过过滤器toRange,将拿到的数值转换为具有这个数值个数的数组,这个数组会自动赋值给空数组,作为循环对象。

转载于:https://my.oschina.net/u/2399867/blog/742761

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值