记录vue项目中遇到的一点小问题
1、鼠标悬浮显示不同的背景图片,代码如下
效果如图,页面初始效果
鼠标悬浮后效果
2、for 循环发送axios遇到的问题 问题背景
在声动语商项目中,需求更改后,出现一个教师发布课程的时候要求一个课程发送给多个班级。
现在的接口每次只能发送一个班级的id,也就是classesId字段只能传一个班级的id,为了满足这个新需求就想着将select修改为多选,使用for循环循环用户选中的班级数组,使用axios发送创建课程请求。更改后的界面如下图所示
问题复现
思路使用for循环,发送axios,发现请求发送的data中classesId总是一个,立马想到了闭包,以为是闭包问题,于是使用
这种方法想着解决下闭包,重新发送axios请求发现classesId数据还是不对。然后自我怀疑,以为自己写的闭包是不是有啥问题....
于是使用了第三方lodash的forEach方法一下,将axios请求写到了foreach里面,重新运行还是发现不对。。。。
以为this指向有问题,有将this重新赋值,结果还是一样。。。。。。。
于是又调整了一下代码将axios请求重新封装出去,重新在for循环里面调用,结果还是不对
打断点发现for循环出来的classesId数据是对的,加上axios请求,每次请求发送的classesId还只是一个的
又想着是不是axios的异步请求影响的,于是将axios改为了同步请求,结果还是一样,这个时候,整个人就有点不好了。。。。
眼看着快要下班了,而这个问题已经看了一下午还没有解决,就很着急啊啊啊啊
努力回想自己曾经这样请求过啊,当时并没有发生任何不对。于是想着将请求的数据简化一下,就将发送的data数据简化到了只有classesId,想着只有一个数据了,就没有再定义任何的变量,直接将数据写到了axios请求内部。运行发现classesId竟然是对的。。。。于是立马将其他数据都写到了axios请求内容,发现结果对了,天啊,终于看到了希望。。。。
问题原因
将这两种数据的定义及发送方式对比,分析问题可能是因为 js赋值的深拷贝和浅拷贝造成的。。。
其他
解决过程中还试了watch监听for循环classesId的变化,发现也只能监听获取到一个classesId.,并不能解决这个问题
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程