JavaScript、angular2中如何从for循环的值中重组一个数组
问题描述
比如我有一个数组
let arry = [{'selected':true,'name':'Tony'},{'selected':false,'name':'Lily'},{'selected':true,'name':'Liyang'}];
JS中我使用for循环如何获取仅selected为true的值?
for(var i=0;i<arry.length;i++){ if(arry[i].selected=true){console.log(arry[i].name) }}
以上的for中国,打印出来的依然是3个字符串。而我仅需要['Tony','Liyang']这样的格式,我该如何才能获取?之前试过使用push添加到一个空数组中,但是push中每for一次就仅push当前for到的值,而并不会将所有值添加到一个数组中去!求大神帮帮忙!
问题解答
回答1:if(arry[i].selected=true)
这里错了,写成了赋值。
回答2:一个=是赋值,两个=是比较,楼主下次写的时候细心点,有时候逻辑没问题,但就是运行不起来,那么可能是哪个位置语法有问题了。
回答3:直接用arry[i].selected判定就好了,为啥要判断值是否相等啊?
回答4:var newArr = []arry.forEach(function(value){if(value.selected) newArr.push(value.name)})回答5:
用 filter 和 map 处理多方便的
let arry = [ { 'selected': true, 'name': 'Tony' }, { 'selected': false, 'name': 'Lily' }, { 'selected': true, 'name': 'Liyang' }];let selected = arry.filter(m => m.selected);console.log('selected', selected);let names = selected.map(m => m.name);console.log('names', names);// 连起来let result = arry .filter(m => m.selected) .map(m => m.name);console.log('result', result);
相关文章:
1. pycharm运行python3.6突然出现R6034问题,请问如何处理?2. javascript - 有什么兼容性比较好的办法来判断浏览器窗口的类型?3. fragment - android webView 返回后怎么禁止重新渲染?4. android - react-native 的headless.js Java API 的代码怎么使用?5. javascript - Express 和 request 如何代理远程图片?6. mac连接阿里云docker集群,已经卡了2天了,求问?7. 如何使用git对word文档进行版本控制?8. javascript - vue2如何获取v-model变量名9. javascript - 你们怎样实现前端分页的?10. python小白,关于函数问题
