Muf*_*fin 6 javascript multi-select angularjs
我想从angularJS中的选定复选框项中获取逗号分隔的字符串.同时,当从数据库中恢复逗号分隔的字符串时,我希望相应地检查复选框.
<div class="col-md-5">
<input type="checkbox" ng-model="Drawings.CarMDrawings" ng-change="Update(Drawings)"> Car
<br />
<input type="checkbox" ng-model="Drawings.SignalMDrawings" ng-change="Update(Drawings)"> Signal
<br />
<input type="checkbox" ng-model="Drawings.DoorMDawings" ng-change="Update(Drawings)"> Door
<br />
</div>
Run Code Online (Sandbox Code Playgroud)
我以非常简单的方式解决了问题是Plunker http://plnkr.co/edit/YYd5bN5Chmyjt6gSH1Bw?p=preview
$scope.Update = function(Drawings) {
var str = "";
if (Drawings.CarMDrawings) {
str = "Car";
}
if (Drawings.SignalMDrawings) {
str = str + ",Signal";
}
if (Drawings.DoorMDawings) {
str = str + ",Door";
}
if (str.charAt(0) === ',') {
str = str.substr(1);
}
$scope.data = str;
}
$scope.revUpdate = function(data) {
var str = data;
$scope.Drawings = {};
if (str.indexOf('Car') != -1) {
$scope.Drawings.CarMDrawings = true;
}
if (str.indexOf('Signal') != -1) {
$scope.Drawings.SignalMDrawings = true;
}
if (str.indexOf('Door') != -1) {
$scope.Drawings.DoorMDawings = true;
}
Run Code Online (Sandbox Code Playgroud)
}
但是当我有很多类似的东西时它没有用.任何人都可以帮我构建一个指令或扩展,以便我可以经常重用它们.PS我不想要对象数组,而是简单的逗号分隔字符串项.
如果您使用“indexOf”,您将得到许多垃圾项目,其中包含您想要查找的文本。
所以我认为这是获得更精确值的最接近的方法。
if (new RegExp("\\b"+"Car"+"\\b").test(str)) {
$scope.Drawings.CarMDrawings = true;
}
var str="test ,Car ,test"; //true
var str="test, Car, test"; //true
var str="test Cartest"; //false
var str="testCar test"; //false
Run Code Online (Sandbox Code Playgroud)
也许这是一个很晚的答案,但我希望这符合您的意图,
并且对其他会看到这个的人有帮助。:)
| 归档时间: |
|
| 查看次数: |
1553 次 |
| 最近记录: |