jjzjj

javascript - 推送时 ng-repeat 失败

coder 2024-04-30 原文

我有 Angular 问题,这是我的代码

HTML

<div class="row">
<div class="col-sm-12">
    <div class="panel panel-default">
        <div class="panel-heading">
            <h3 class="panel-title">Insertar presupuesto</h3>
        </div>
        <div class="panel-body">
            <!-- Trigger the modal with a button -->
            <button type="button" class="btn btn-info btn-lg" data-toggle="modal" data-target="#seleccionarp">Buscar producto</button>
            <!-- Modal -->
            <div id="seleccionarp" class="modal fade" role="dialog">
                <div class="modal-dialog">
                    <!-- Modal content-->
                    <div class="modal-content">
                        <div class="modal-header">
                            <button type="button" class="close" data-dismiss="modal">&times;</button>
                            <h4 class="modal-title">Seleccione su producto</h4>
                        </div>
                        <div class="modal-body">
                            <label for="Buscar cliente  ">Buscar producto:</label>
                            <input class="form-control" id="buscarproducto" ng-model="busqueda[queryBy]" value="" placeholder="Buscar" />
                            <div>
                                <table class="table table-hover">
                                    <tr>
                                        <th>Descripcion</th>
                                        <th>Color</th>
                                        <th>Talle</th>
                                        <th>Stock</th>
                                        <th>Precio</th>
                                    </tr>
                                    <tbody ng-repeat="emp in posts | filter:busqueda">
                                        <tr ng-click="comprar(emp)" data-dismiss="modal">
                                            <td>{{emp.nombre_producto}}</td>
                                            <td>{{emp.color}}</td>
                                            <td>{{emp.talle}}</td>
                                            <td>{{emp.stock}}</td>
                                            <td>{{emp.precio | currency}}</td>
                                        </tr>
                                    </tbody>
                                </table>
                            </div>
                        </div>
                        <div class="modal-footer">
                            <button type="button" class="btn btn-default" data-dismiss="modal">Cerrar</button>
                        </div>
                    </div>
                </div>
            </div>
            <table class="table table-hover">
                <thead>
                    <tr>
                        <th>Nombre del producto</th>
                        <th>Cantidad</th>
                        <th>Precio</th>
                        <th>Total</th>
                        <th></th>
                    </tr>
                </thead>
                <tbody ng-repeat="p in carrito track by $index">
                    <input type="hidden" name="id_producto[]" value="{{p.id_producto}}" ng-model="p.id_producto" class="form-control">
                    <input type="hidden" name="color[]" value="{{p.color}}" ng-model="p.color" class="form-control">
                    <input type="hidden" name="talle[]" value="{{p.talle}}" ng-model="p.talle" class="form-control">
                    <tr>
                        <td>
                            <input type="text" name="nombre_producto[]" ng-model="p.nombre_producto" class="form-control">
                        </td>
                        <td>
                            <input type="number" name="stock[]" ng-model="p.stock" value="1" onClick="this.select();" class="form-control">
                        </td>
                        <td>
                            <input type="text" name="precio[]" ng-model="p.precio" onClick="this.select();" class="form-control" value="">
                        </td>
                        <td>{{p.stock * p.precio | currency}}</td>
                        <td>
                            <button type="button" class="btn btn-danger" ng-click="remove($index)">Eliminar</button>
                        </td>
                    </tr>
                </tbody>
            </table>
            <h2>Total:${{total()}}</h2>
            <input type="hidden" name="total_remito" value="{{total()}}">
            <button type="submit" name="button">guardar</button>
        </div>
    </div>
</div>

AngularJS

app.controller("ctrlremitos", function($scope, $http) {

$scope.posts = [];

$scope.carrito = [];

$scope.clienteasignado = [];

$scope.clientes = [];

$scope.busqueda = {}

$scope.busquedaclientes = {}

$scope.queryBy = '$'

$scope.newPost = {};

$http.get(base_url + "venta/get_productos").success(function(data, timeout) {
    $scope.posts = data;
}).error(function(err) {})

$http.get(base_url + "venta/get_clientes").success(function(data) {
    $scope.clientes = data;
}).error(function(err) {})

$scope.comprar = function(_item, index) {
    $scope.carrito.push(_item)
}

$scope.asignarcliente = function(_item) {
    $scope.clienteasignado.push(_item)
}

$scope.remove = function(index) {
        $scope.carrito.splice(index, 1);
    },

    $scope.total = function() {
        var total = 0;
        angular.forEach($scope.carrito, function(p) {
            total += p.stock * p.precio;
        })
        return total;
    }

});

问题是,当我选择一个产品时,会进行推送,但值(value)始终是股票的值(value),我想要的是,当你进行推送时,你总是将股票值(value)更改为 1。我注意到的另一件事是当更改“库存”字段中的值时,在搜索产品的数组中也发生了更改,我不知道该怎么做:(我已经尝试使它正常工作很多天了,我希望他们将照亮道路。

问候

https://github.com/outthesystem/facturacion-codeigniter

最佳答案

"$scope.total"是一个函数,不是一个作用域变量。 因此,除非您进行显式调用,否则双向绑定(bind)在这种情况下不起作用。 让它工作: 对 Controller 和 HTML 进行以下更改。 Controller 更改:

$scope.total = 0;

$scope.comprar = function(_item, index) {
    $scope.carrito.push(_item);
    $scope.calculateTotal(); //Make an explicit call to calculation method
}

$scope.calculateTotal = function()
{
     angular.forEach($scope.carrito, function(p) {
            $scope.total += p.stock * p.precio;
        })
};

HTML 更改:

<h2>Total:${{total}}</h2>
            <input type="hidden" name="total_remito" value="{{total}}">

希望对你有帮助

关于javascript - 推送时 ng-repeat 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41254732/

有关javascript - 推送时 ng-repeat 失败的更多相关文章

  1. ruby - 即使失败也继续进行多主机测试 - 2

    我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r

  2. ruby-on-rails - 创建 ruby​​ 数据库时惰性符号绑定(bind)失败 - 2

    我正在尝试在Rails上安装ruby​​,到目前为止一切都已安装,但是当我尝试使用rakedb:create创建数据库时,我收到一个奇怪的错误:dyld:lazysymbolbindingfailed:Symbolnotfound:_mysql_get_client_infoReferencedfrom:/Library/Ruby/Gems/1.8/gems/mysql2-0.3.11/lib/mysql2/mysql2.bundleExpectedin:flatnamespacedyld:Symbolnotfound:_mysql_get_client_infoReferencedf

  3. ruby - 正则表达式在哪个位置失败? - 2

    我需要一个非常简单的字符串验证器来显示第一个符号与所需格式不对应的位置。我想使用正则表达式,但在这种情况下,我必须找到与表达式相对应的字符串停止的位置,但我找不到可以做到这一点的方法。(这一定是一种相当简单的方法……也许没有?)例如,如果我有正则表达式:/^Q+E+R+$/带字符串:"QQQQEEE2ER"期望的结果应该是7 最佳答案 一个想法:你可以做的是标记你的模式并用可选的嵌套捕获组编写它:^(Q+(E+(R+($)?)?)?)?然后你只需要计算你获得的捕获组的数量就可以知道正则表达式引擎在模式中停止的位置,你可以确定匹配结束

  4. ruby - 使用 rbenv 和 ruby​​-build 构建 ruby​​ 失败,出现 undefined symbol : SSLv2_method - 2

    我正在尝试在配备ARMv7处理器的SynologyDS215j上安装ruby​​2.2.4或2.3.0。我用了optware-ng安装gcc、make、openssl、openssl-dev和zlib。我根据README中的说明安装了rbenv(版本1.0.0-19-g29b4da7)和ruby​​-build插件。.这些是随optware-ng安装的软件包及其版本binutils-2.25.1-1gcc-5.3.0-6gconv-modules-2.21-3glibc-opt-2.21-4libc-dev-2.21-1libgmp-6.0.0a-1libmpc-1.0.2-1libm

  5. ruby-on-rails - Ruby 的 'open_uri' 是否在读取或失败后可靠地关闭套接字? - 2

    一段时间以来,我一直在使用open_uri下拉ftp路径作为数据源,但突然发现我几乎连续不断地收到“530抱歉,允许的最大客户端数(95)已经连接。”我不确定我的代码是否有问题,或者是否是其他人在访问服务器,不幸的是,我无法真正确定谁有问题。本质上,我正在读取FTPURI:defself.read_uri(uri)beginuri=open(uri).readuri=="Error"?nil:urirescueOpenURI::HTTPErrornilendend我猜我需要在这里添加一些额外的错误处理代码...我想确保我采取一切预防措施来关闭所有连接,这样我的连接就不是问题所在,但是我

  6. ruby-on-rails - 使用 javascript 更改数据方法不会更改 ajax 调用用户的什么方法? - 2

    我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的

  7. ruby-on-rails - Ruby 流量控制 : throw an exception, 返回 nil 还是让它失败? - 2

    我在思考流量控制的最佳实践。我应该走哪条路?1)不要检查任何东西并让程序失败(更清晰的代码,自然的错误消息):defself.fetch(feed_id)feed=Feed.find(feed_id)feed.fetchend2)通过返回nil静默失败(但是,“CleanCode”说,你永远不应该返回null):defself.fetch(feed_id)returnunlessfeed_idfeed=Feed.find(feed_id)returnunlessfeedfeed.fetchend3)抛出异常(因为不按id查找feed是异常的):defself.fetch(feed_id

  8. ruby - gem 规范失败 - 2

    我正在为毕业设计开发GEM,TravisCI构建不断失败。这是我在Travis上的链接:https://travis-ci.org/ricardobond/perpetuus/builds/8709218构建错误是:$bundleexecrakerakeaborted!Don'tknowhowtobuildtask'default'/home/travis/.rvm/gems/ruby-1.9.3-p448/bin/ruby_noexec_wrapper:14:in`eval'/home/travis/.rvm/gems/ruby-1.9.3-p448/bin/ruby_noexec_

  9. arrays - Ruby 数组 += vs 推送 - 2

    我有一个数组数组,想将元素附加到子数组。+=做我想做的,但我想了解为什么push不做。我期望的行为(并与+=一起工作):b=Array.new(3,[])b[0]+=["apple"]b[1]+=["orange"]b[2]+=["frog"]b=>[["苹果"],["橙子"],["Frog"]]通过推送,我将推送的元素附加到每个子数组(为什么?):a=Array.new(3,[])a[0].push("apple")a[1].push("orange")a[2].push("frog")a=>[[“苹果”、“橙子”、“Frog”]、[“苹果”、“橙子”、“Frog”]、[“苹果”、“

  10. ruby-on-rails - "rails generate rspec:install"似乎失败了 - 2

    运行:ruby1.9.3p0和Rails3.2.1尝试使用rspec但当我尝试将其安装到我的应用程序中时出现以下错误:/Users/Si/.rvm/gems/ruby-1.9.3-p0/gems/railties-3.2.1/lib/rails/railtie/configuration.rb:85:in`method_missing':undefinedmethod`generators'for#(NoMethodError)from/Users/Si/.rvm/gems/ruby-1.9.3-p0/gems/rspec-rails-2.0.0.beta.18/lib/rspec-r

随机推荐