错误:“请求中止” axios laravel vuejs

时间:2020-04-03 11:06:31

标签: php laravel vue.js axios

我想使用laravel,vuejs和axios添加一个函数,但是它给了我错误Error: "Request aborted"。如果我删除表单验证系统和checkForm函数,一切都很好,真的我不知道什么错误标志什么,什么样的错误。

fonction.blade.php

<section id="main-content">
 <section class="wrapper">
  <div class="container" id="app">
   <div id="login-page">
    <div class="form-login">
     <div class="login-wrap">
      <form @submit="checkForm">
        <div v-if="errors.length">
          <div class="alert alert-danger" role="alert">
            <ul>
              <li v-for="error in errors">@{{ error }}</li>
            </ul>
          </div>
        </div>
        <input type="text" class="form-control" id="fonction" name="fonction" v-model="fonction.fonction" placeholder="fonction">
        <br>
        <button class="btn btn-theme" @click="addFonction">AJOUTER FONCTION</button>
      </form>
     </div>
      </div>
    </div>
  </div>
 </section>
</section>
<script src="{{asset('js/vue.js')}}"></script>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

vuejs

    <script>
        window.Laravel = {!! json_encode([
            'csrfToken' => csrf_token(),
            'url' => url('/')
        ]) !!};
    </script>

<script>
       var app = new Vue({  
        el: '#app',
        data: {
            errors: [],
            fonctions:[],
            fonction:{
                fonction :''
            }
        },
        methods:{
           checkForm: function (e) {
            if (this.fonction.fonction) {
              return true;
            }
            this.errors = [];
            if (!this.fonction.fonction) {
              this.errors.push('fonction required.');
            }
            e.preventDefault();
          },
            addFonction:function(){
                axios.post(window.Laravel.url+'/addfonction/', this.fonction)
                .then(response => {
                  //console.log(response.data);
                    this.fonctions.unshift(this.fonction);
                    this.fonction={
                            fonction:''
                        }
                })
                .catch(error=>{
                    console.log(error);
                })
            },
            },
    });
</script>

SalarieController.php

public function addFonction(request $request){
      $fonction = new Fonction;
      $fonction->fonction = $request->fonction;
      $fonction->save();
      Response()->json(['etat' => true]);
    }

1 个答案:

答案 0 :(得分:0)

同样的问题,也许它与<form>标签相连。
我可以通过将<form>标签替换为<div>标签来解决问题。同样,我将所有submit个事件替换为按钮上的click个事件。