javascript - 减少 switch 语句中的数组 (AngularJS)

标签 javascript angularjs multidimensional-array angularjs-scope angularjs-ng-repeat

很抱歉这篇文章标题中的描述很肤浅,但我会在本文中更好地解释它。但是,在我的 Ctrl 中,我使用 switch 语句来说明什么是大的。有点大,我正在寻找一种解决方案来最小化它或使其更加灵活。

简短描述其工作原理。目前该 View 包含 6 个复选框。所有复选框在 ngClick 指令中都有一个方法 choose(r.val)。因此,当用户与复选框交互时,choose 方法会调用 switch 语句。为什么?检查单击了哪个复选框。具有该值的相应情况将被执行。所有复选框都会使用数组 $scope.tableOptions = [...],这意味着 View 中定义了一个 ngRepeat 指令来显示所选的表。

代码如下:

$scope.choose = function (value) {
   switch (value) {
      case 1:
          $scope.changeDate = function (selDate) {
              CrudService.getArticle(selDate).$promise.then(
                   function (response) {
                      $scope.repos = response;
                   },
                   function (err) {
                      $log.info('error:', err);
                   });
          }

          $scope.tableOptions = [
               { columnTitle: 'Datum' },
               { columnTitle: 'ArtNr' },
               { columnTitle: 'Description' },
               { columnTitle: 'Price' }
          ];

          $scope.rowOptions = [
               { rowTitle: 'datum' },
               { rowTitle: 'artnr' },
               { rowTitle: 'descr' },
               { rowTitle: 'price' }
          ];
          break;
      case 2:
          $scope.changeName = function (selName) {
               CrudService.getNames(selName).$promise.then(
                   function (response) {
                      $scope.repos = response;
                   },
                   function (err) {
                      $log.info('error:', err);
                   });
          }

          $scope.tableOptions = [
               { columnTitle: 'Datum' },
               { columnTitle: 'Firstname' },
               { columnTitle: 'Lastname' },
               { columnTitle: 'Address' },
               { columnTitle: 'Age' }
          ];

          $scope.rowOptions = [
               { rowTitle: 'Datum' },
               { rowTitle: 'fname' },
               { rowTitle: 'lname' },
               { rowTitle: 'address' },
               { rowTitle: 'age' }
          ];
          break;
      case 3:
          ... // and so on..

为了更好地想象它,我添加了此示例的 View :

<div class="table-responsive">
   <table class="table table-bordered table-hover">
      <thead>
         <tr>
           <th ng-repeat="tblOpt in tableOptions">
              {{ tblOpt.columnTitle }}
           </th>
         </tr>
      </thead>
      <tbody>
         <tr ng-repeat="r in repos">
           <td ng-repeat="row in rowOptions">
              {{ r[row.rowTitle] }}
           </td>
         </tr>
      </tbody>
   </table>
</div>

我的想法是将数组相互嵌套。但也许对此有更好的解决方案。如何更智能地定义数组?

最佳答案

不确定这是否正是您想要的,但这是简化代码并使其更加模块化的一种方法。是将你的函数分成四个函数中的三个而不是一个。例如,您可以有一个名为构建表选项的函数和一个名为构建行选项的函数,这将使您的代码更加灵活、模块化并且更易于测试

这是一个例子,您也可以分解出数据调用部分,但如果没有看到其余代码,我无法给出一个很好的例子

$scope.choose = function (value) {
   switch (value) {
      case 1:
          $scope.changeDate = function (selDate) {
              CrudService.getArticle(selDate).$promise.then(
                   function (response) {
                      $scope.repos = response;
                   },
                   function (err) {
                      $log.info('error:', err);
                   });
          }

           $scope.buildTableOptions(['Datum' ,  'ArtNr' , 'Description' , 'Price']);
           $scope.buildRowOptions([ 'datum','artnr' ,'descr' ,'price']);
          break;
      case 2:
          $scope.changeName = function (selName) {
               CrudService.getNames(selName).$promise.then(
                   function (response) {
                      $scope.repos = response;
                   },
                   function (err) {
                      $log.info('error:', err);
                   });
          }

          $scope.buildTableOptions(['Datum', 'Firstname', 'Lastname', 'Address', 'Age']);
          $scope.buildRowOptions(['Datum' , 'fname','lname','address','age']);
          break;

   } 


  $scope.buildOptions = function(type, names){
      var options = [];
      names.forEach(function(el){

          var obj = {}
          obj[type] = el;
          options.push(obj)   

      }); 

      return options;        

  };


  $scope.buildTableOptions = function(options){

    $scope.rowOptions = $scope.buildOptions('columnTitle', options)

  };

   $scope.buildRowOptions = function(options){

    $scope.rowOptions = $scope.buildOptions('rowTitle', options)

  };

关于javascript - 减少 switch 语句中的数组 (AngularJS),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32641022/

相关文章:

javascript - 仅使用 HTML-CSS 制作在缩放调整后保持在原位的叠加 <div>

javascript - 是否记录了 Android 的 JavaScript 环境?

javascript - Angularjs 焦点意外地需要异步 setTimeout 才能工作

javascript - 调用 $ (".myItem").dateInput() 后,angularjs 输入字段未更新

javascript - 为什么父组件和子组件之间的双向绑定(bind)不好?

c++ - 在类中创建 vector 的 vector (二维数组)- 错误 :C++ requires a type specifier for all declarations

C# 交错数组类型声明反向

javascript - 无法解析模块说明符 "vee-validate"。相对引用必须以 "/"、 "./"或 "../"开头

javascript - Symbol.toPrimitive 与 Object.prototype.valueOf

c# - 将 T[,] 转换为 T[][] 的最快方法?