select
从元素传递对象时,元素上的 ng-model 存在问题option
。因此,假设我们有一个名为(表的定义)的表中的列数组,columns
我们想根据这个定义创建一些过滤器
var columns = [
{name: 'Account ID', type: 'numeric'},
{name: 'Full name', type: 'text'},
{name: 'Date of birth', type: 'date'},
{name: 'Active', type: 'boolean'}
// and so on
];
var filters = [{}];
HTML:
<div class="form-field" ng-repeat="filter in filters">
<select ng-model="filter">
<option value="" disabled>Choose filter</option>
<option ng-repeat="column in columns" ng-value="column">{{column.name}}</option>
</select>
<input type="text" ng-model="filter.value">
</div>
正如你所看到的,我希望filter
得到它的值column
并在其中添加特定的数据,所以在某个时刻,我的过滤器可能是这样的:
[
{name: 'Account ID', type: 'numeric', value: 123},
{name: 'Active', type: 'boolean', value: 'Yes'}
]
无论如何,我不确定这是这样做的方式,但我想知道如何实现这种行为,而无需在控制器中编写大量 js 代码。
我做了一些解决方法来完成这项工作ng-change
,传递filter
和column.name
,在数组中找到列columns
,获取type
属性,更新filter
,但我真的认为有一个更简单的答案。