- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 ng-repeat 中有选择列表列。我在每个重复中也有复选框列。假设我有一个预定义的税值,应将其更新为我已检查的行的选择列表项。
我怎样才能实现这个目标?在选择列表中使用 ng-model 会更新所有项目,即完整列而不是选定的行。
这是代码。
$scope.data = {
products: [
{ name: "Product #1", description: "A product",
category: "Category #1", price: 100, isChecked:false,
taxList: [
{label: "Vat 20%"},
{label: "Vat 30%"},
{label: "Vat 40%"}
]
},
{ name: "Product #2", description: "A product",
category: "Category #1", price: 110, isChecked:false,
taxList: [
{label: "Vat 20%"},
{label: "Vat 30%"},
{label: "Vat 40%"}
]
},
{ name: "Product #3", description: "A product",
category: "Category #2", price: 210, isChecked:false,
taxList: [
{label: "Vat 20%"},
{label: "Vat 30%"},
{label: "Vat 40%"}
]
},
{ name: "Product #4", description: "A product",
category: "Category #3", price: 202, isChecked:false,
taxList: [
{label: "Vat 20%"},
{label: "Vat 30%"},
{label: "Vat 40%"}
]
}]
};
angular.forEach($scope.data.products, function(product){
product.taxList.unshift({label: "Select Tax"});
$scope.selectedTax = product.taxList[0].label;
});
$scope.updateListTax = function(){
$scope.preDefinedTax = "Vat 40%";
angular.forEach($scope.data.products, function(product){
if(product.isChecked){
$scope.selectedTax = $scope.preDefinedTax;
}
});
}
ul,li{
list-style:none;
}
.group:after{
content: '';
display: table;
clear: both;
}
<div class="col-sm-12">
<section>
<div class="group">
<div class="col-sm-6"><strong>Product Details</strong></div>
<div class="col-sm-6"><strong>Tax</strong></div>
</div>
<ul>
<li ng-repeat="item in data.products" class="row">
<div class="col-sm-6">
<span class="col-sm-1">
<input type="checkbox" ng-model="item.isChecked">
</span>
<span class="col-sm-11">{{item.name}}</span>
</div>
<div class="col-sm-6">
<select ng-options="tax.label as tax.label for tax in item.taxList" ng-model="selectedTax"></select>
</div>
</li>
</ul>
<button ng-click="updateListTax()" class="btn btn-default">save</button>
</section>
最佳答案
selectedTax 位于父范围内,因此对于每个产品来说都是相同的。将 selectedTax 键添加到每个项目对象并使用 ng-model。
$scope.data = {
products: [
{ name: "Product #1", description: "A product",
category: "Category #1", price: 100, isChecked:false,
taxList: [
{label: "Vat 20%"},
{label: "Vat 30%"},
{label: "Vat 40%"}
]
},
selectedTax: null
...
angular.forEach($scope.data.products, function(product){
product.taxList.unshift({label: "Select Tax"});
product.selectedTax = product.taxList[0].label;
});
$scope.updateListTax = function(){
$scope.preDefinedTax = "Vat 40%";
angular.forEach($scope.data.products, function(product){
if(product.isChecked){
product.selectedTax = $scope.preDefinedTax;
}
});
}
HTML
<select ng-options="tax.label as tax.label for tax in item.taxList" ng-model="item.selectedTax"></select>
关于javascript - 使用预定义值更新 ng-repeat 中的选择列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37628056/
我对我接管的项目有疑问。我正在转换其他人编写的 MS Access 应用程序并将其转换为 MySQL/PHP Web 应用程序。其中大部分已经完成,但是,当涉及到此应用程序的调度部分时,我处于停滞状态
我有一个带有 @Scheduled 注释的方法。此方法包含长时间运行、昂贵的操作。我担心当计划的方法开始运行时应用程序会变慢。有什么办法可以为预定方法分配优先级吗?在 Spring 中启动低优先级后台
我的大学有一个预订项目房间的网站;但除非你很幸运或者半夜醒着,否则要订到房间并不容易。因此,我编写了一个 JS 片段来填写所有必要的字段并提交表单。 但是我如何自动化这个过程呢? 我的目的基本上是加载
我正在评估处理大量排队消息的可能解决方案,这些消息必须在特定日期和时间交付给工作人员。执行它们的结果主要是对存储数据的更新,它们最初可能是也可能不是由用户操作触发的。 例如,想想你在一个假设的大型星际
@Scheduled documentation here声明 fixedRateString值可以是 the delay in milliseconds as a String value, e.g
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
我有一个有趣的情况。我解析了几个新闻发布网站,想通过调度程序将它们保存到数据库中。但是保存时出现错误。由于交易后写条件 described here . 我的模型类是 @Entity @Table(n
我正在阅读 Java Concurrency in Practice 并遇到以下代码片段。 public static void timedRun(final Runnable r,
使用 Azure 数据工厂,是否可以对驻留在 Azure SQL 数据库中的多个(不是全部)表中的所有行执行预定的 1:1 复制/克隆到另一个 Azure SQL 数据库(在本例中为 Azure SQ
我是一名优秀的程序员,十分优秀!