2017-04-23 89 views
0

我想對vue.js但顯示在容器0元素每次mixitup目標使用mixitup。(mixer.getStatu().totalShow使用mixitup與Vue.js 2.0組件

在這裏,我完全vue.js組件代碼

<template> 
    <section class="main-container object-non-visible" data-animation-effect="fadeInUpSmall" data-effect-delay="200"> 

     <div class="container"> 
      <div class="row"> 
       <div class="main col-md-12"> 
        <h1 class="page-title text-center">Fiziki Gerçekleşme Görselleri</h1> 
        <div class="separator"></div> 
         <div class="text-center" v-show="!showMap"> 
          <p><span class="glyphicon glyphicon-refresh"></span> Harita yükleniyor...</p> 
         </div> 

        <highmaps :options="options" ref="map" v-if="showMap"></highmaps> 

        <div class="filters text-center" id="control_buttons" v-show="showControlButtons"> 
         <p v-show="refreshButtons"><span class="glyphicon glyphicon-refresh"></span> Yükleniyor...</p> 
         <button class="btn btn-white control" data-filter="all">Tümü</button> 
         <button type="button" class="btn btn-white control" 
           v-for="h in hospitals" 
           :data-filter="setDataFilterClass(h.id)" 
           @click="mixitUpFilter(setDataFilterClass(h.id))">{{h.hospital_name}}</button> 
        </div> 

       </div> 
      </div> 
     </div> 
     <div class="gray-bg section" v-show="showControlButtons"> 
      <div class="mixitup-container"> 
       <slot v-for="h in hospitals"> 
        <div v-for="photo in h.photos" :class="setFilterClass(h.id)"></div> 
       </slot> 
       <div class="gap"></div> 
       <div class="gap"></div> 
       <div class="gap"></div> 
      </div> 
     </div> 
    </section> 
</template> 

<script> 
    import VueHighcharts from 'vue-highcharts' 
    Vue.use(VueHighcharts, { Highcharts }) 

    import mixitup from 'mixitup' 


    export default{ 
     name:'physicalimagesmap', 
     data(){ 
      var self = this; 
      return { 
       mapDataUrl:'/report/hospital-city-map-data', 
       mapHcKeyDataUrl:'/report/hospital-city-detail-by-hckey', 
       mapType:{'map_statu':'yatak'}, 
       hospitalsData:[], 
       mixitFilters:[], 
       options:{ 
        lang:{ 
         downloadJPEG: 'JPEG Olarak İndir', 
         downloadPDF: 'PDF Olarak İndir', 
         downloadPNG: 'PNG Olarak İndir', 
         downloadSVG: 'SVG Olarak İndir', 
         printChart: 'Grafiği Yazdır' 
        }, 
        title : { 
         text : '' 
        }, 
        subtitle : { 
         text : '' 
        }, 

        mapNavigation: { 
         enabled: true, 
         buttonOptions: { 
          verticalAlign: 'bottom' 
         } 
        }, 

        colors: ['rgba(19,64,117,0.05)', 'rgba(19,64,117,0.2)', 'rgba(19,64,117,0.4)', 
        'rgba(19,64,117,0.5)', 'rgba(19,64,117,0.6)', 'rgba(19,64,117,0.8)', 'rgba(19,64,117,1)'], 


        legend: { 
         title: { 
          text: 'Yatak Sayısı (Toplam)', 
          style: { 
           color: (Highcharts.theme && Highcharts.theme.textColor) || 'black' 
          } 
         }, 
         layout: 'vertical', 
         align: 'right', 
         floating: true, 
         valueDecimals: 0, 
         valueSuffix: '', 
         backgroundColor: (Highcharts.theme && Highcharts.theme.legendBackgroundColor) || 'rgba(255, 255, 255, 0.85)', 
         symbolRadius: 0, 
         symbolHeight: 14, 
         x:0, 
         y:20 
        }, 

        colorAxis: { 
         dataClasses: [{ 
          from: 0, 
          to: 200 
         }, { 
          from: 200, 
          to: 500 
         }, { 
          from: 500, 
          to: 1000 
         }, { 
          from: 1000, 
          to: 2000 
         }, { 
          from: 2000, 
          to: 4000 
         }, { 
          from: 4000, 
          to: 5000 
         },{ 
          from: 6000 
         }] 
        }, 

        exporting: { 
         chartOptions: { 
          colorAxis: { 
           dataClasses: [ 
           { 
            from: 1, 
            to: 200 
           }, { 
            from: 200, 
            to: 500 
           }, { 
            from: 500, 
            to: 1000 
           }, { 
            from: 1000, 
            to: 2000 
           }, { 
            from: 2000, 
            to: 4000 
           }, { 
            from: 4000, 
            to: 5000 
           },{ 
            from: 6000 
           }] 
          } 
         } 
        }, 
        credits:{ 
         enabled:false 
        }, 
        series:[{ 
         animation: { 
          duration: 1000 
         }, 
         data : [], 
         mapData: Highcharts.maps['countries/tr/tr-all'], 
         dataLabels: { 
          enabled: true, 
          formatter: function() { 
           if (this.point.properties) { 
            return this.point.properties['name']; 
           } 
          }, 
          format: null, 
          style: { 
           fontWeight: 'bold' 
          } 
         }, 
         joinBy: ['hc-key'], 
         name: 'Yatak Sayısı', 
         cursor: 'pointer', 
         point:{ 
          events:{ 
           click:function(e){ 

            self.hcKey = e.point['hc-key']; 
            self.refreshButtons = true; 
            self.getCityHospitalData(); 
            console.log(mixer.getState().totalShow); 




           } 
          } 
         } 
        }] 
       }, 
       showMap:false, 
       hcKey:'', 
       showControlButtons:false, 
       hospitals:{}, 
       refreshButtons:false 
      } 
     }, 
     methods:{ 
      setMap(){ 
       var self = this; 
       axios.post(this.mapDataUrl,this.mapType) 
       .then(function (response) { 
        self.options.series[0].data = response.data 
        self.showMap = true; 
       }); 
      }, 
      getCityHospitalData(){ 
       var self = this 
       if(this.hcKey!==''){ 
        axios.post(this.mapHcKeyDataUrl,{'hcKey':this.hcKey}) 
        .then(function (response) { 
         self.hospitals = response.data.hospitals 
         self.showControlButtons = true 
         self.refreshButtons = false 
         mixer.forceRefresh() 
        }).catch(function(error){ 
         console.log(error); 
        }); 
       } 
      }, 
      setDataFilterClass(hospitalId){ 
       return '.hospital-image-'+hospitalId 
      }, 
      setFilterClass(hospitalId){ 
       return 'mix hospital-image-'+hospitalId 
      }, 
      mixitUpFilter(filterClass){ 
       mixer.filter(filterClass) 
      } 
     }, 
     mounted(){ 
      this.setMap() 
      window.mixer = mixitup($('.mixitup-container')) 
     } 

    } 
</script> 

我使用ajax(axios)獲取控件和容器元素。因此它們是動態創建的。

但mixitup不顯示容器元素和控制按鈕。我試過mixer.destroy()mixer.forceRefresh()但它不起作用。

任何想法和幫助,將不勝感激。

感謝

回答

0

你的設置肯定是更復雜一點,但我建立的示例回購只是爲了確保Vue.js和MixItUp可以很好地協同工作,因爲我還需要同時使用它們。

https://github.com/jordanboston/mixitup-vue-example

這是剛剛從Kunk Labs網站採取的一個基本的例子。我使用npm i -S mixitup選項,它運行良好,至少對於像這樣的基本示例。

希望這可以有所幫助。

+0

好的,謝謝約旦 – kodcu