国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

Vue項目中使用jquery的簡單方法

來源:懂視網 責編:小采 時間:2020-11-27 21:56:53
文檔

Vue項目中使用jquery的簡單方法

Vue項目中使用jquery的簡單方法:前言 在vue項目中,需要實現某些特定的功能時,使用mvvm模式不易實現。因此引入jquery包來完成需求 jquery中的觸發事件可以自己定義在mounted中,如果需要使用vue中data的數據,直接使用this.msg是無法使用的,需要另外定義const _this = th
推薦度:
導讀Vue項目中使用jquery的簡單方法:前言 在vue項目中,需要實現某些特定的功能時,使用mvvm模式不易實現。因此引入jquery包來完成需求 jquery中的觸發事件可以自己定義在mounted中,如果需要使用vue中data的數據,直接使用this.msg是無法使用的,需要另外定義const _this = th

前言

在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重新計數
 }
 }
 })

小白一枚,如果有其他更好的方法,歡迎各位同行指教,多多交流

總結

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

Vue項目中使用jquery的簡單方法

Vue項目中使用jquery的簡單方法:前言 在vue項目中,需要實現某些特定的功能時,使用mvvm模式不易實現。因此引入jquery包來完成需求 jquery中的觸發事件可以自己定義在mounted中,如果需要使用vue中data的數據,直接使用this.msg是無法使用的,需要另外定義const _this = th
推薦度:
標簽: 辦法 VUE 的方法
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 日韩精品一区二区三区不卡 | 国产成人综合一区精品 | 日本激情网址 | 国产网站在线看 | 欧美一级网站 | 一道本一区二区三区 | 日本人乱人乱亲乱色视频观看 | 97精品国产91久久久久久 | 亚洲区精品久久一区二区三区 | 久久久久久亚洲精品影院 | 欧美一区二区免费 | 欧美极品第1页专区 | 欧美三级一区二区 | 麻豆国产成人精品午夜视频 | 日韩欧美在线免费观看 | 国产日韩欧美综合 | 91在线免费看 | 久久精品国产三级不卡 | 国产成人精品第一区二区 | 久久精品综合国产二区 | 国产资源网站 | 天天躁日日躁狠狠躁中文字幕老牛 | 日韩综合在线视频 | 国产亚洲欧美一区 | 欧美国产精品 | 欧美精品一区二区精品久久 | 国产精品视频免费观看 | 国产成人99久久亚洲综合精品 | 欧美日韩中字 | 久久精品国产一区二区三区 | 阿v精品一区二区三区 | 日本啊v| 精品一区二区三区高清免费不卡 | 一区不卡在线观看 | 99国产视频 | 欧美日a | 91精品久久久久久久久久 | 国产免费资源高清小视频在线观看 | 天天做夜夜做久久做狠狠 | 成人久久久 | 亚洲欧美日韩中文无线码 |