Vuejs自訂select2指令

來源:互聯網
上載者:User

標籤:target   ini   nod   cti   directive   hang   pre   div   named   

  在做select2外掛程式的時候遇到一些坑,最終解決如下:

  Vue.directive(‘select2‘, {        inserted: function (el, binding, vnode) {            var options = binding.value || {};            var defaultOpt = {                placeholder: "--請選擇--",                allowClear: true            };            options = _.assign(defaultOpt, options);            $(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 })); //雙向繫結不生效                //綁定選中選項的事件                options && options.onSelect && options.onSelect(e);            });            //allowClear:清除選中            $(el).select2(options).on("select2:unselecting", (e) => {                //清空這個值,這個值即vuejs model綁定的值                e.target.value = "";                el.dispatchEvent(new Event(‘change‘, {                    target: e.target                })); //雙向繫結不生效            });            //綁定select2 dom渲染完畢時觸發的事件            options && options.onInit && options.onInit();        },        update: function (el, binding, vnode) {            $(el).trigger("change");        }    });

 

Vuejs自訂select2指令

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.