2016-06-21 68 views
0

我的问题:如果我在[]行中的ng-repeat =“n中放置了一个整数[],它可以工作,但我想要的是能够使用stock.price | BuySellAmount:ctrl.money这是一个自定义过滤器,基本上将人的总金额除以该股的价值。但是当我只是添加stock.price | BuySellAmount:在[]中的ctrl.money我得到一个错误。那么如何在[]中添加该信息?在ng-repeat中获取最大数量的可购买产品

  <div ng-if="stock.price | BuySellAmount:ctrl.money" class="input-group col-md-1"> 
       <select class="form-control "> 
       <option ng-repeat="n in [] | makeRange" ng-selected= "{{n == stock.price | BuySellAmount:ctrl.money}}">{{n}}</option> 
       </select>    
       <span class="input-group-btn"> 
       <button ng-if="stock.price | BuySellAmount:ctrl.money" class="btn btn-success" ng-click="buyStock()">Buy</button> 
       </span> 
      </div> 



(function() { 
     'use strict'; 
     angular 
     .module('MODULE') 

     // controller 
     .controller('CONTROLLER',['$http', function($http){ 
      var self = this; 

      self.money = 50; 

      // get the json feed and create a new array with the prices and labels 
      $http.get('js/stocks.json') 
      .success(function(data, status, headers, config) { 
       //self.stockList = angular.copy(data.stocks); 
       //console.log(self.stockList); 
       var stocks = []; 
       for (var i = 0; i < data.stocks.length; i++) { 
        stocks.push({ 
         name: data.stocks[i].name, 
         price: Math.floor(Math.random()*(600-data.stocks[i].price+1)+data.stocks[i].price) 
        }); 
       } 
       self.stockList = stocks; 
      }) 
      .error(function(data, status, headers, config) { 
       // log error 
      }); 


     }]) 
     .filter('randomPrice', function() { 
     return function(min, max) 
     { 
      var max = 5000; 
      console.log() 
      return Math.floor(Math.random()*(max-min+1)+min); 
     } 
    }) 


    .filter('BuySellAmount', function() { 
     return function(stockprice,moneyinhand) 
     { 
      //Math.random()*(max-min+1)+min 
      var amount = Math.floor(moneyinhand/stockprice); 
      return amount; 
     } 
    }) 

    .filter('makeRange', function() { 
     return function(input) { 
      var lowBound, highBound; 
      switch (input.length) { 
      case 1: 
       lowBound = 0; 
       highBound = parseInt(input[0]) - 1; 
       break; 
      case 2: 
       lowBound = parseInt(input[0]); 
       highBound = parseInt(input[1]); 
       break; 
      default: 
       return input; 
      } 
      var result = []; 
      for (var i = lowBound; i <= highBound; i++) 
       result.push(i); 
      return result; 
     }; 
    }); // end 
    })(); 
+1

1.有活生生的例子总是有帮助。 2.我不明白你想达到什么目的。也许你应该尝试分解你的问题一点点 –

+0

我清理它。我希望你能更好地理解它。谢谢! – rchiriboga

+0

所以你想迭代'stock.price |的结果BuySellAmount:ctrl.money' in'ng-repeat =“n in [] | makeRange”',对不对? –

回答

0

对于那些可能有此问题的人。我希望不要太难遵循,我能够把stock.price | BuySellAmount:内的{{}}中的[]使用()代替ctrl.money的NG-重复

新的NG-重复

<div ng-if="stock.price | BuySellAmount:ctrl.money" class="input-group col-md-1"> 
       <select class="form-control "> 
       <option ng-repeat="n in [(stock.price | BuySellAmount:ctrl.money)] | makeRange" ng-selected= "{{n == stock.price | BuySellAmount:ctrl.money}}">{{n}}</option> 
       </select>    
       <span class="input-group-btn"> 
       <button ng-if="stock.price | BuySellAmount:ctrl.money" class="btn btn-success" ng-click="buyStock()">Buy</button> 
       </span> 
      </div> 
+1

你做'stock.price | BuySellAmount:ctrl.money'三次,而它只能完成一次。你应该小心使用过滤器,因为它们是在每个摘要上评估的。在这里找到如何优化你的代码:[SO回答](http://stackoverflow.com/a/11722324/1065780) –

相关问题