English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Ejemplo de implementación de filtros y funciones de eliminación complejos en Angular

Este artículo expone cómo Angular implementa funciones de filtrado y eliminación de tablas más complejas. Lo compartimos para que todos lo puedan consultar, como se detalla a continuación:

Veamos primero el efecto de ejecución:

El código específico es el siguiente:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">-8" />
    <title>es.oldtoolbag.com Filtros Angular, eliminación</title>
    <style>
      table{
        border: 1px solid black;
        width: 800px;
      }
      td , th{
        border: 1px solid black;
        text-align: center;
      }
      th{
        background: #767674;
      }
      .d1{
        width: 50%;
        margin: 0 auto;
      }
      .d2{
        margin-top: 10px;
      }
      .btn{
        background: green;
        color: white;
      }
      .btn1{
        background: red;
        color: white;
      }
      tr:nth-child(2n){
        background-color: gainsboro;
      }
    </style>
    <script src="angular.min.js"></script>
    <script type="text/javascript" src="jquery-1.9.1.min.js" ></script>
    <script>
      angular.module("MyApp",[])
      .controller("democ",function($scope,$filter){
        $scope.isc = false;
        $scope.arrs = [{
                
                id:7,
                name:"OPPO R9s",
                user:"赵云",
                tel:15777777777,
                price:4999,
                city:"北京",
                time:new Date('03-09 10:00'),
                sta:"已发货"
               },
               {
                
                id:12,
                name:"VIVO X20",
                user:"关羽",
                tel:15333333333,
                price:2998,
                city:"上海",
                time:new Date('08-22 10:00'),
                sta:"已发货"
               },
               {
                
                id:1,
                name:"iPhone 8 Plus",
                user:"曹操",
                tel:15111111111,
                price:7588,
                city:"北京",
                time:new Date('09-04 10:00'),
                sta:"已发货"
               },
               {
                
                id:11,
                name:"小*Note5"
                user:"黄忠",
                tel:13222222222,
                price:699,
                city:"重庆",
                time:new Date('02-28 10:00'),
                sta:"Enviado"
               },
               {
                
                id:1,
                name:"小*Mix2"
                user:"黄盖",
                tel:13111111111,
                price:3299,
                city:"北京",
                time:new Date('03-015 10:00'),
                sta:"Enviado"
               };
               $scope.arr = $scope.arrs;
               $scope.seluser = function(){
                 $scope.arr = [];
                 var val = $scope.reg_user;
                 var f = $filter("filter");
                 $scope.arr = f($scope.arrs,{"user":val});
               }
               $scope.seltel = function(){
                 $scope.arr = [];
                 var val = $scope.reg_tel;
                 var f = $filter("filter");
                 $scope.arr = f($scope.arrs,{"tel":val});
               }
               $scope.selsta = function(){
                $scope.arr = [];
                var val = $scope.reg_sta;
                var f = $filter("filter");
                $scope.arr = f($scope.arrs,{"sta":val});
               }
               $scope.ckAll = function(){
                var ck = $scope.sta_ck;
                for(var i=0; i<$scope.arrs.length; i++{
                  $scope.arrs[i].checked = ck;
                }
               }
               
                $scope.arrs.splice(th,1);
               }
               $scope.delAll = function(){
                for(var i=0; i<$scope.arrs.length; i++{
                  
                    $scope.arrs.splice(i,1);
                    i--;
                  }
                }
               }
               $scope.add = function(){
                var d=new Date();
                
                  
                  
                  
                  
                  
                  
                  
                  time:d,
                  sta:"Enviado"
                });
                $scope.arr = $scope.arrs;
                $scope.isc = false;
               }
      });
    </script>
  </head>
<body ng-app="MyApp" ng-controller="democ">
    <div class="d1">
      <div>
        <input type="text" placeholder="Búsqueda de nombre de usuario" ng-change="seluser()" ng-model="reg_user"/>
        <input type="text" placeholder="Búsqueda de número de teléfono" ng-change="seltel()" ng-model="reg_tel"/>
        <select>
          <option>Seleccione ciudad</option>
          <option>Beijing</option>
          <option>Shanghai</option>
          <option>Guangzhou</option>
        </select>
        <select ng-change="selsta()" ng-model="reg_sta">
          <option value="">Seleccione estado</option>
          <option value="发货">Enviado</option>
          <option value="已发货">Entregado</option>
        </select>
        <select ng-model="selid">
          <option value="">--Por favor, seleccione--</option>
          <option value="id">ID ascendente</option>
          <option value="-id">ID inverso</option>
        </select>
        <select ng-model="selmonth">
          <option value="">mes inicial</option>
          <option value="1">1</option>
          <option value="2">2</option>
          <option value="3">3</option>
          <option value="4">4</option>
          <option value="5">5</option>
          <option value="6">6</option>
          <option value="7">7</option>
          <option value="8">8</option>
          <option value="9">9</option>
          <option value="10">10</option>
          <option value="11">11</option>
          <option value="12">12</option>
        </select>
        <select ng-model="lastmonth">
          <option value="">mes final</option>
          <option value="1">1</option>
          <option value="2">2</option>
          <option value="3">3</option>
          <option value="4">4</option>
          <option value="5">5</option>
          <option value="6">6</option>
          <option value="7">7</option>
          <option value="8">8</option>
          <option value="9">9</option>
          <option value="10">10</option>
          <option value="11">11</option>
          <option value="12">12</option>
        </select>
      </div>
      <div class="d2">
        <input type="button" value="nuevo pedido" class="btn" ng-click="isc=true"/>
        <input type="button" value="enviar en lote" class="btn"/>
        <input type="button" value="eliminar en lote" class="btn"1" ng-click="delAll()"/>
        palabra sensible: 米(商品名)->reemplazar con*
      </div>
      <div>
        <table cellpadding="0" cellspacing="0">
          <tr>
            <th><input type="checkbox" ng-change="ckAll()" ng-model="sta_ck"/></th>
            <th>ID</th>
            <th>商品名</th>
            <th>用户名</th>
            <th>手机号</th>
            <th>价格</th>
            <th>城市</th>
            <th>下单时间</th>
            <th>状态</th>
            <th>操作</th>
          </tr>
          <tr ng-repeat="a in arr|orderBy : selid | filter:{time:selmonth} | filter:{time:lastmonth}">
            <td><input type="checkbox" ng-model="a.checked"/></td>
            <td>{{a.id}}</td>
            <td>{{a.name}}</td>
            <td>{{a.user}}</td>
            <td>{{a.tel}}</td>
            <td>{{a.price|currency : '¥'}}</td>
            <td>{{a.city}}</td>
            <td>{{a.time|date : 'MM-HH hh:dd:ss'}}</td>
            <td>
              <span ng-show="a.sta=='enviado'">{{a.sta}}</span>
              <span ng-show="a.sta=='enviado'"><a href="#" rel="external nofollow" ng-click="a.sta='enviado'">{{a.sta}}</a></span>
            </td>
            <td><input type="button" value="Eliminar" ng-click="del(this)"/></td>
          </tr>
        </table>
      </div>
      <div ng-show="isc">
           I D:<input type="text" ng-model="a_id"/><br />
           Nombre del producto:<input type="text" ng-model="a_name"/><br />
           Nombre de usuario:<input type="text" ng-model="a_user"/><br />
           Número de teléfono:<input type="text" ng-model="a_tel"/><br />
           Valor:<input type="text" ng-model="a_price"/><br />
          Ciudad:<input type="text" ng-model="a_city"/><br />
          <input type="button" value="Guardar" ng-click="add()"/>
      </div>
    </div>
  </body>
</html>

PS:Todavía hay algunas funciones incompletas en el código, los amigos interesados pueden probar y modificar por su cuenta para perfeccionar.

Los lectores interesados en más contenido relacionado con AngularJS pueden consultar la sección especial de este sitio: 'Resumen de Trucos de Operación de Directivas AngularJS', 'Tutorial de Entrada y Avance en AngularJS' y 'Resumen de Arquitectura MVC de AngularJS'.

Espero que lo descrito en este artículo pueda ayudar a todos en el diseño de programas AngularJS.

Declaración: El contenido de este artículo se ha obtenido de la red, pertenece al propietario original, el contenido se ha contribuido y subido por los usuarios de Internet de manera autónoma. Este sitio no posee los derechos de propiedad, no ha sido editado por humanos y no asume ninguna responsabilidad legal relacionada. Si encuentra contenido sospechoso de infracción de derechos de autor, por favor envíe un correo electrónico a: notice#oldtoolbag.com (al enviar un correo electrónico, reemplace # con @) para denunciar y proporcionar evidencia relevante. Una vez confirmado, este sitio eliminará inmediatamente el contenido sospechoso de infracción.

Te gustará