这篇文章将为大家详细讲解有关如何在Vue项目中使用jquery,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
前言
在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是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。
关于如何在Vue项目中使用jquery就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。