【vue】Vue中的map()用法


前言

记录vue常用得map(),喜欢在前台处理数据,但是map()用得也不熟悉。这两天频繁用,也没看到好的参考样例(可能好的我没找到)。就自己试着写琢磨出来,自己记录一下。省的以后用再去翻找(自己脑子记不住哇 T_T ).


一、map()是什么?

其实我也不清楚,会用就好啦。数组操作是前端最重要的数据操作,构造数组数据,重构解析数组又是数组操作中很常见的。下面我将写出我得心得和map()在Vue项目中的使用。

二、使用

1.案例一:取给定数组的某一字段组成新数组

的后台传来的数据 data(json):

[   //data的数据
	{"txt":"09:00-12:00","codId":"1","flgDel":"0","id":1},
	{"txt":"13:00-16:00","codId":"1","flgDel":"0","id":2},
	{"txt":"18:00-20:00","codId":"1","flgDel":"0","id":3}
]

前台使用要为:

['09:00-12:00', '13:00-16:00', '18:00-20:00']

用到map()只需一行(我同学想要用到for循环遍历出来)我就觉得很麻烦,只记得之前貌似用过map()。快捷方法出来了学去吧。

let time = data.map(item =>(item.txt))
console.log(time) 
//控制台输出如下
//['09:00-12:00', '13:00-16:00', '18:00-20:00']

2.案例二:取给定数组的某些字段重命名并组成新数组

新的接口传来data(json):

[  //新data数据
{"txt":"拜访","flgDel":"0","id":1},
{"txt":"面试","flgDel":"0","id":2},
{"txt":"其他","flgDel":"0","id":3}
]

前台使用数组结构:

[{ name: '拜访' }, { name: '面试' }, { name: '其他' }]
//这里看到相比于案例一有字段了,还新命名了
//只需一行map()
let resion = data.map(item =>({name: item.txt}))
console.log(resion) 
//控制台输出
//[{ name: '拜访' }, { name: '面试' }, { name: '其他' }]

当然,或许你要的这样⬇ :

[{ name: '拜访',id:'1' }, { name: '面试',id:'2' }, { name: '其他',id:'3'}]
//要两个字段的数据
let resion2 = data.map(item =>({name: item.txt, id: item.id}))
console.log(resion2) 
//控制台输出
//[{ name: '拜访',id:'1' }, { name: '面试',id:'2' }, { name: '其他',id:'3'}]

又或许你想要这样⬇ :

[{ name: '拜访1' }, { name: '面试2' }, { name: '其他3'}]
//要拼接的数据
let resion3 = data.map(item =>({name: item.txt + item.id}))
console.log(resion3) 
//控制台输出
//[{ name: '拜访1' }, { name: '面试2' }, { name: '其他3'}]
//这数据看着好奇怪,没这么用的。我只想说map()可这么用😁,还有更多等我们一起探索

三、总结

方便太多了同学都来向我请教了,写的明白易懂吧相信也会用了(小白教程)。
以上就是今天要记录的内容,本文仅仅简单介绍了map()在vue中数据处理的一点皮毛,而map()提供了大量能使我们快速便捷地处理数据的函数和方法还等待我去使用发现

  • 101
    点赞
  • 252
    收藏
    觉得还不错? 一键收藏
  • 28
    评论
Vue3使用vue-baidu-map的方法如下: 1. 首先,安装vue-baidu-map依赖包。可以通过npm或者yarn进行安装。 2. 在vue组件引入BMap,并在mounted钩子函数创建地图实例。注意,在Vue3,需要使用import语法引入BMap,例如:import BMap from 'BMap'。 3. 在mounted钩子函数,使用BMap创建地图实例,并设置地图的心点和缩放级别。 4. 添加地图标注:使用BMap.Marker创建标注实例,并将其添加到地图上。 5. 可选地,添加信息窗口:使用BMap.InfoWindow创建信息窗口实例,并使用map.openInfoWindow()方法开启信息窗口。 6. 可选地,为标注添加点击事件,当点击标注时开启信息窗口。 以下是一个示例代码: ```html <template> <div class="map"> <div id="map"></div> </div> </template> <script> import BMap from 'BMap' export default { mounted() { const map = new BMap.Map('map') const point = new BMap.Point(118.750801, 31.944156) map.centerAndZoom(point, 15) const marker = new BMap.Marker(point) map.addOverlay(marker) const opts = { width: 100, height: 50 } const infoWindow = new BMap.InfoWindow('这里显示地址详细信息', opts) marker.addEventListener('click', function() { map.openInfoWindow(infoWindow, point) }) } } </script> ``` 以上代码展示了在Vue3使用vue-baidu-map的基本流程。你需要根据自己的需求,在上述基础上进行进一步的定制和添加功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vue3 使用百度地图,踩坑日历](https://blog.csdn.net/hjg1224/article/details/121241972)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [vue-baidu-map离线百度地图,并附带jar包免费下载百度瓦片数据](https://download.csdn.net/download/HZC961850356/82034496)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值