起步
1 | npm install jquery |
jquery 中的触发事件可以自己定义在 mounted 中,如果需要使用 vue 中 data 的数据,直接使用 this.msg 是无法使用的,需要另外定义 const _this = this,
存储 this 之后便可以在事件中使用_this.msg 数据了。
需求:在品牌处可以输入,并且会有模糊搜索的下拉框,也可下拉选择,在输入完毕后检验值是否在下拉框中存在,聚焦时蓝色边框,change 时如果不存在则红框显示,存在的话就绿框提示,(就是带输入建议的输入框)
问题: 使用 element-ui 中的 el-autocomplete 组件,开始通过失焦事件来验证,但是如果选择了下拉框某个值时(选中后会将下拉框的值赋给上面的输入框),失焦事件触发会在赋值之前,因此拿失焦时输入框的值来进行判断时错误的,在先改变输入框的值后再去选择下拉框,change 事件有同样的 bug,没办法只能自己引入 jquery 来完成
点击输入框后,通过 placeholder 判断是否是品牌下的的输入框,因为每个输入框都有这个类,如果是的话则增加一个类名,如果第一次点击的位置和第二次鼠标点击的位置都是品牌下的输入框,则执行相应的逻辑判断,
在逻辑执行完后就删除其他处同样的类名 inputList
1 | const _this = this; |
此处是为了模拟出输入框的 change 事件,因为在聚焦时会添加 inputList 这个类名。所以这里可以判断是否是自己想要的位置,如果是的话给一个标志位 getindex,当点击到品牌下的输入框时,如果第二次的点击位置不是品牌其他位置的输入框,则进行逻辑判断
1 | $(document).click(function (e) { |
I'm so cute. Please give me money.
- Post link: https://blog.gaocaipeng.com/2020/06/23/rz8ngc/
- Copyright Notice: All articles in this blog are licensed under unless otherwise stated.