Vue中使用jquery
2019-05-15 17:02
645 查看
在vue项目中,需要实现某些特定的功能时,使用mvvm模式不易实现。因此引入jquery包来完成需求
jquery中的触发事件可以自己定义在mounted中,如果需要使用vue中data的数据,直接使用this.msg是无法使用的,需要另外定义const _this = this,
存储this.之后便可以在事件中使用_this.msg数据了。
需求:在品牌处可以输入,并且会有模糊搜索的下拉框,也可下拉选择,在输入完毕后检验值是否在下拉框中存在,聚焦时蓝色边框,change时如果不存在则红框显示,存在的话就绿框提示,(就是带输入建议的输入框)
问题: 使用element-ui中的el-autocomplete组件,开始通过失焦事件来验证,但是如果选择了下拉框某个值时(选中后会将下拉框的值赋给上面的输入框),失焦事件触发会在赋值之前,因此拿失焦时输入框的值来进行判断时错误的,在先改变输入框的值后再去选择下拉框,change事件有同样的bug,没办法只能自己引入jquery来完成
点击输入框后,通过placeholder判断是否是品牌下的的输入框,因为每个输入框都有这个类,如果是的话则增加一个类名,如果第一次点击的位置和第二次鼠标点击的位置都是品牌下的输入框,则执行相应的逻辑判断,
在逻辑执行完后就删除其他处同样的类名inputList
const _this = this
$('body').delegate('.el-input__inner', 'focus', function(e) { // 因为是动态生成的,所以选择这种方式来监听事件 if (e.target.placeholder === '请输入品牌') { // 当聚焦在品牌输入框时触发 $(this).addClass('inputList') // 加上一个类名inputList if ($('.inputList').length === 2) { // 判断下一次点击的位置,当从第一个输入框改值后下一个聚焦位置还是品牌下的输入框时 if (!$('.inputList').not(this).val()) { $('.inputList').not(this).css('border', '1px solid #67c23a') } else { let num = 0 for (let j = 0; j < _this.goodsBrands.length; j++) { if ($('.inputList').not(this).val() === _this.goodsBrands[j].value) { num += 1 break } } if (num === 0) { _this.$message.error('输入的品牌不在品牌列表中') $('.inputList').not(this).css('border', '1px solid #F56C6C') } else { $('.inputList').not(this).css('border', '1px solid #67c23a') } } } $('.el-input__inner').not(this).removeClass('inputList') // 逻辑执行完之后删除当前聚焦位置以外的inputList类,这样就保持.inputList长度最多为2 } })
此处是为了模拟出输入框的change事件,因为在聚焦时会添加inputList这个类名。所以这里可以判断是否是自己想要的位置,如果是的话给一个标志位getindex,当点击到品牌下的输入框时,如果第二次的点击位置不是品牌其他位置的输入框,则进行逻辑判断
$(document).click(function(e) { // focus触发时也会触发这个事件,并且触发在focus事件之后 if (e.target.classList[1] === 'inputList') { // 判断是否点击在对应位置 _this.getIndex = 1 // 用于标志在聚焦事件触发后的下一次点击是否同样会触发聚焦,如果是则把第二次点击当成第一次重新判断,等到下一次点击再来判断 } else { if (_this.getIndex === 1) { if (!$('.inputList').eq(0).val()) { $('.inputList').eq(0).css('border', '1px solid #67c23a') } else { let num = 0 for (let j = 0; j < _this.goodsBrands.length; j++) { if ($('.inputList').eq(0).val() === _this.goodsBrands[j].value) { num += 1 break } } if (num === 0) { _this.$message.error('输入的品牌不在品牌列表中') $('.inputList').eq(0).css('border', '1px solid #F56C6C') } else { $('.inputList').eq(0).css('border', '1px solid #67c23a') } } $('.el-input__inner').removeClass('inputList') _this.getIndex = 0 // 每次第二次点击了其他位置时,getIndex重新计数 } } })
小白一枚,如果有其他更好的方法,欢迎各位同行指教,多多交流
相关文章推荐
- vue 中使用jquery
- vue项目中使用jQuery
- VUE使用jquery
- Vue中正确使用jQuery的方法
- 如何将 jQuery 从你的 Bootstrap 项目中移除(取而代之使用Vue.js)
- 在Vue项目中使用npm安装bootstrap以及jquery
- 使用Jquery与vuejs操作dom比较
- 使用vue-cli开发过程中如何把jQuery设置为全局
- Vue.js 使用Vue.js和Jquery做增删改查
- webpack构建VUE项目使用jquery及其插件 expose-loader
- 浅析angular,react,vue.js jQuery使用区别
- jquery在vue脚手架中的使用方式
- 使用vue与jquery实时监听用户输入状态的操作代码
- jquery在vue脚手架中的使用方式示例
- vue项目中使用jQuery
- Vue系列——在vue项目中使用jQuery及其第三方插件
- 浅析angular,react,vue.js jQuery使用区别
- [译]怎样在Vue.js中使用jquery插件
- 在vue里使用 jquery
- vue单页应用中如何使用jquery的方法示例