Публикация вакансии не будет удалена, продолжайте получать идентификатор "неопределено" - PullRequest
0 голосов
/ 14 ноября 2018

У меня проблема с моим небольшим приложением. В настоящее время у меня есть страница вакансии, я могу опубликовать и получить работу.

На веб-интерфейсе у меня есть кнопка, чтобы нажать Delete, но когда я это делаю, она продолжает выдавать мне эту ошибку - DELETE FROM 'jobs' WHERE 'id' = 'undefined'.

В настоящее время используются такие технологии, как MySQL, sequelize, node.js, express и vue.js.

Консоль

<div>
    <h2 class="mb-4 font-weight-light">Job postings</h2>
    <div class="d-flex align-items-center justify-content-between">
      <b-input-group class="w-30">
        <b-form-input v-model="filter" placeholder="Type to Search" />
        <b-input-group-append>
          <b-btn :disabled="!filter" @click="filter = ''">Clear</b-btn>
        </b-input-group-append>
      </b-input-group>
      <b-button variant="primary" class="d-flex align-items-center" v-b-modal.addJob><i class="material-icons mr-1"></i> Add job</b-button>
    </div>
    <b-table responsive hover :items="jobs" :fields="fields" :filter="filter" no-sort-reset sort-by="postedOn" :sort-desc="true" class="mt-3 f6">
        <template slot="job_postingURL" slot-scope="data">
            <a :href="`${data.value}`" target="_blank">{{ data.value }}</a>
        </template>

        <template slot="Remove" scope="jobs">
           <b-btn variant="danger" @click="deleteJob(jobs.ID)"> Delete </b-btn>
        </template>
    </b-table>
    <add-job></add-job>
</div>
</template>


<script>
import AddJob from '@/components/jobs/AddJob'
import JobService from '../../services/JobService'
import axios from 'axios'

export default {
  components: {
    AddJob
  },
    data () {
        return {
            fields: [
              { Key: 'ID', label: 'Job ID', sortable: false},
              { key: 'job_title', label: 'Job title', sortable: true },
              { key: 'job_name', label: 'Company name', sortable: true },
              { key: 'job_location', label: 'Location', sortable: true },
              { key: 'job_postingURL', label: 'Job posting link', sortable: false },
              { key: 'job_postingOn', label: 'Posted on', sortable: true, tdClass: 'text-right' },
              { key: 'job_postingBy', label: 'Posted by', sortable: true },
              { key: 'Remove', sortable: true }
            ],
            filter: null,
            jobs: [
              {  
                  ID: '',           
                  job_title: '',
                  job_name: '',
                  job_location: '',
                  job_postingURL: '',
                  job_postingOn: '',
                  job_postingBy: ''
              },
          ],
        }
    },
    // this method is to get the data from database
   async created () {
    try {
      this.jobs = await JobService.getJobs();
    } catch(err) {
      this.error = err.message;
    }
  },
  methods: {
      deleteJob (ID) {
        axios.delete(`http://localhost:5000/api/jobs/${this.ID}`)
          .then((res) => {
            this.ID = ''
            this.job_title = ''
            this.job_name = ''
            this.job_location = ''
            this.job_postingURL =''
            this.job_postingOn = ''
            this.job_postingBy = ''
            console.log(res)
          })
          .catch((err) => {
            console.log(err)
          })
      }
  }
}

</script>

1 Ответ

0 голосов
/ 15 ноября 2018

Поскольку у вас есть jobs как свойство объекта данных, вы не можете использовать jobs в качестве slot-scope значения, попробуйте что-то вроде row, в этом случае row объект содержит некоторые свойства, такие как item, которыесодержать данные о текущем элементе, показанном в этой строке, поэтому вы должны сделать:

     <template slot="Remove" slot-scope="row">
       <b-btn variant="danger" @click="deleteJob(row.item.ID)"> Delete </b-btn>
    </template>

и в вашем методе:

   deleteJob (ID) {
    axios.delete('http://localhost:5000/api/jobs/'+ID)
      .then((res) => {...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...