2015-10-06 146 views
1

我在調用函數this.fetchReports時出現Uncaught TypeError: this.fetchReports is not a function錯誤似乎我可以從swal對象訪問此函數,如何使此函數成爲全局函數?我正在使用Vuejs和SweetAlert,這是我的代碼。Vuejs Sweetalert未捕獲類型錯誤

methods: { 
    fetchReports: function() { 
    this.$http.get('/reports/vueGetRequest', function (reports) { 
     this.$set('reports', reports); 
     //this.reports = reports; 
    }) 
    }, 
    sortBy: function (ordenarpor) { 
    this.reverso = (this.ordenarpor == ordenarpor) ? !this.reverso : false; 
    this.ordenarpor = ordenarpor; 
    }, 
    //Borrar usuario 
    borrarUsuario: function (id) { 
    // this.initial.id = 'borrar_confirmation'; 
    // this.initial.appendChild(this.texto_confirmation); 
    // this.container = this.initial.textContent; 
    // this.container = this.initial.id; 

    swal({ 
     title: "Desea borrarlo?", 
     text: "Una vez borrado no se podra recuperar", 
     type: "warning", 
     showCancelButton: true, 
     confirmButtonColor: "#DD6B55", 
     confirmButtonText: 'si', 
     closeOnConfirm: false 
    }, function (isConfirm) { 
     //swal("Eliminado!", "Ha sido eliminado exitosamente!!", "success"); 
     if (isConfirm) { 
     //this.$http.post('/reports/vueGetRequest' , id); 
     Vue.http.post('/reports/vueGetRequest', id); 
     // refresh the page una vez eliminado 
     this.fetchReports(); 
     swal("Eliminado!", "Ha sido eliminado correctamente!!.", "success"); 
     } else { 
     swal("Cancelado", "Cancelado :)", "error"); 
     } 
    }); 
    } 
} 

回答

2

你的問題是this SwaI位回調函數內的值。

你可以嘗試這樣的事:

borrarUsuario: function (id) { 
    var self = this; // <------ 

    swal({ 
    title: "Desea borrarlo?", 
    text: "Una vez borrado no se podra recuperar", 
    type: "warning", 
    showCancelButton: true, 
    confirmButtonColor: "#DD6B55", 
    confirmButtonText: 'si', 
    closeOnConfirm: false 
    }, function (isConfirm) { 
    if (isConfirm) { 
     Vue.http.post('/reports/vueGetRequest', id); 
     self.fetchReports(); // <------ 
     swal("Eliminado!", "Ha sido eliminado correctamente!!.", "success"); 
    } else { 
     swal("Cancelado", "Cancelado :)", "error"); 
    } 
    }); 
} 

或者:

borrarUsuario: function (id) { 
    swal({ 
    title: "Desea borrarlo?", 
    text: "Una vez borrado no se podra recuperar", 
    type: "warning", 
    showCancelButton: true, 
    confirmButtonColor: "#DD6B55", 
    confirmButtonText: 'si', 
    closeOnConfirm: false 
    }, function (isConfirm) { 
    if (isConfirm) { 
     Vue.http.post('/reports/vueGetRequest', id); 
     this.fetchReports(); 
     swal("Eliminado!", "Ha sido eliminado correctamente!!.", "success"); 
    } else { 
     swal("Cancelado", "Cancelado :)", "error"); 
    } 
    }.bind(this)); // <------ 
} 
+0

非常感謝您的幫助,它適用於我:)。 – Hustels

0

在Vuejs實例中的任何功能可以使用實例變量調用。

var vm=new Vue({ 
    el:'#app', 
    data:{}, 
    methods: { 
     fetchReports:function(){ 
     //do your stuff 
    } 
    } 
}); 

//Outside in javascript file you can call 

    vm.fetchReports();