Search code examples
vue.jsmaterialize

Vuejs + Materializecss select field


I have this code in my template:

<div class="input-field col s6">
    <select v-on:change="selectChaned" v-model="item.size">
        <option value="" disabled selected>Choose your option</option>
        <option v-on:click="optionClicked" v-for="size in case_sizes" v-bind:value="{{ size }}">{{ size }}</option>
    </select> 
    <label for="size">Size</label>
</div>

According to Materializecss docs, I call $('select').material_select(); to transform default select field into something cutie. What it also does - it replaces <select> and <option> tags with <ul> and <li>. As a result I can't access value of item.size in my ViewModel js file. I even tried to listen for a click on option field and call optionClicked method (which should simply alert a message then), tried to listen for selectChaned. Nothing.

How can I get option value in ViewModel?

p.s. just for information: I only have problem with select field. Input field for example works fine:

<input placeholder="" name="name" type="text" class="validate" v-model="item.name">

In ViewModel I'm able to access item.name


Solution

  • It seems that Materialize doesn't dispatch any events so I couldn't find an elegant solution. But it does seem that the following Vuejs directive + jQuery workaround is working:

    Vue.directive("select", {
        "twoWay": true,
    
        "bind": function () {
            $(this.el).material_select();
    
            var self = this;
    
            $(this.el).on('change', function() {
                self.set($(self.el).val());
            });
        },
    
        update: function (newValue, oldValue) {
            $(this.el).val(newValue);
        },
    
        "unbind": function () {
            $(this.el).material_select('destroy');
        }
    });
    

    And then in your HTML – bind <select> using v-select instead of v-model.