怎么在vue2組件中對(duì)select2進(jìn)行調(diào)用?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)建站專注于鳩江企業(yè)網(wǎng)站建設(shè),成都響應(yīng)式網(wǎng)站建設(shè),商城系統(tǒng)網(wǎng)站開(kāi)發(fā)。鳩江網(wǎng)站建設(shè)公司,為鳩江等地區(qū)提供建站服務(wù)。全流程專業(yè)公司,專業(yè)設(shè)計(jì),全程項(xiàng)目跟蹤,創(chuàng)新互聯(lián)建站專業(yè)和態(tài)度為您提供的服務(wù)
select下拉搜索選擇
這次的需求調(diào)研與設(shè)計(jì)是原來(lái)做winform開(kāi)發(fā)的同事,由于用慣了devexpress
這個(gè)控件庫(kù),所以,對(duì)于searchlookupeditor
這個(gè)控件情有獨(dú)鐘,所以,在設(shè)計(jì)的時(shí)候,許多地方都用到。
最初實(shí)現(xiàn)
最初,我使用了select2綁定select標(biāo)簽,設(shè)定其change事件 ,在事件中修改對(duì)應(yīng)的vue的data值,同時(shí),在vue中設(shè)定watch``data中被綁定的屬性,屬性值發(fā)生變化,則修改對(duì)應(yīng)的dom的val,然后再觸發(fā)select2的change事件。當(dāng)然,這種對(duì)應(yīng)關(guān)系,我在select標(biāo)簽上放了一個(gè)data-vuep來(lái)保存其與vue屬性的對(duì)應(yīng)關(guān)系,并放在全局的select2vue和dom2vue中。
//mounted中的部分代碼 select2vue = {}; $("select").each(function (index, item) { var s2 = $(item).select2({ language: "zh-CN", //設(shè)置 提示語(yǔ)言 width: "100%", //設(shè)置下拉框的寬度 theme: "classic", placeholder: "請(qǐng)選擇" }).on("change", function (e) { console.log(e); var v = $(e.target).val(); var p = $(e.target).attr("data-vuep"); eval("vue_cust_busi." + p + "='" + v + "';"); //$(e.target).find("option").attr("selected",false); //$(e.target).find("option[value='"+v+"']").attr("selected",true); }); var p = $(item).attr("data-vuep"); select2vue[p] = s2; dom2vue[p] = item; }); setTimeout(function(){ vue_cust_busi.editor.ID_CUST="3"; vue_cust_busi.editor.NAME_CUST="*有限責(zé)任公司"; console.log("修改"); },10,null); //watch中的部分代碼 "temp.P1": function (val) { fire(arguments.callee.name.toString(), val); }, //通用函數(shù) function fire(p, val) { $(dom2vue[p]).val(val); select2vue[p].trigger("change"); } //html
為什么要用一個(gè)data-vuep來(lái)將數(shù)據(jù)與vue的屬性關(guān)聯(lián)呢,因?yàn)槲野l(fā)現(xiàn),select2初始化了這個(gè)select標(biāo)簽之后,修改這個(gè)標(biāo)簽的值無(wú)法觸發(fā)修改vue對(duì)應(yīng)的v-model的屬性。所以,只能用這個(gè)方法。
最終形成的結(jié)果是:
select2到vue.editor.P1:
1.select2被選擇某一項(xiàng),觸發(fā)其change事件。
2.select2的change事件修改vue.editor.P1的值。
3.vue.editor.P1的值被修改,觸發(fā)watch,watch又引發(fā)select2的change事件,但是,select2內(nèi)部監(jiān)控到選擇和之前的一致,所以,不再執(zhí)行change事件的委托。
上面這種流程一定程度是實(shí)現(xiàn)了數(shù)據(jù)的雙向綁定,但是,非常復(fù)雜。在后續(xù)的使用中發(fā)現(xiàn),在mounted中無(wú)法為select2默認(rèn)值,必須在mounted中調(diào)用setTimeout生成一個(gè)定時(shí)執(zhí)行的事件來(lái)執(zhí)行數(shù)據(jù)綁定操作,才會(huì)觸發(fā)上述流程,達(dá)到設(shè)定觸始值的效果。
使用vue指令
經(jīng)過(guò)一番掙扎,覺(jué)得上面這種方式還是不行。
上述方案不好的原因如下:
1.vue事件中的代碼操作了dom,這樣,在生命周期上可能會(huì)出現(xiàn)問(wèn)題,特別是后來(lái)使用了setTimeout之后,生命周期變得更加不可控制。
2.每增加一個(gè)select組件,都需要增加 html標(biāo)簽、watch,而且,html 標(biāo)簽和watch既不是傳統(tǒng)的寫法,也不是vue的寫法,而是發(fā)明了一種新的東西,這破壞了開(kāi)發(fā)體驗(yàn)。
3.維護(hù)性比較差,當(dāng)想刪除一個(gè)select的時(shí)候,必須要去watch里面去找與html中data-vuep相等的屬性監(jiān)控方法,并將其刪除掉。
4.兼容性不好,本方案選擇將頁(yè)面所有的select全部用select2初始化了一次,使得不論是否需要的,都會(huì)被影響;其次,如果不統(tǒng)一初始化,那么又多出了在mounted中為每一個(gè)select寫初始化代碼的工作,同時(shí),也要為每個(gè)select取一個(gè)id。
為了解決這個(gè)問(wèn)題,我又找到了最初看到的那個(gè)vue使用指令和select2的整合的例子。網(wǎng)上有好多,我不知道版權(quán)是誰(shuí)的,姑且上我最先看到的那個(gè)吧。https://www.jb51.net/article/125654.htm
原文中的代碼如下:
vue select2 封裝
結(jié)果:{{ selectValue }}
作者也說(shuō)了,對(duì)vue2.x的雙向綁定機(jī)制不了解,希望路過(guò)的大神幫幫忙。
我不是vue2的大神,甚至連新手都不算,只能說(shuō)是初學(xué)者。我對(duì)代碼進(jìn)行了調(diào)整,當(dāng)然,也是操作了dom,但是由于封裝在指令里面了,使用人員不需要再次操作,不涉及到開(kāi)發(fā)人員操作dom的情況,我還是可以接受的。
Vue.directive('select2', { inserted: function (el, binding, vnode) { let options = binding.value || {}; $(el).select2(options).on("select2:select", (e) => { // v-model looks for // - an event named "change" // - a value with property path "$event.target.value" el.dispatchEvent(new Event('change', { target: e.target })); //說(shuō)好的雙向綁定,竟然不安套路 console.log("fire change in insert"); }); }, update: function (el, binding, vnode) { for (var i = 0; i < vnode.data.directives.length; i++) { if (vnode.data.directives[i].name == "model") { $(el).val(vnode.data.directives[i].value); console.log("new value in update:"+vnode.data.directives[i].value); } } $(el).trigger("change"); console.log("fire change in update"); } }); //html代碼
經(jīng)過(guò)好幾天的研究,終于我發(fā)現(xiàn)在作者原來(lái)的代碼的update中,加入修改el
的val值,然后再觸發(fā)select2的change事件,就可以了。而在使用方面,只需要給加一個(gè)v-select2即可,v-model以及option的配置都依照vue2的推薦方式,原封不動(dòng)。之所以加了一個(gè)空的option是因?yàn)槿绻患樱J(rèn)select2是選擇第一個(gè)選項(xiàng)的,但是,由于未知原因,與vue.editor.P1并不同步。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。