程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Vue/Axios - 使用 url 中的表单数据修补请求?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决Vue/Axios - 使用 url 中的表单数据修补请求??

开发过程中遇到Vue/Axios - 使用 url 中的表单数据修补请求?的问题如何解决?下面主要结合日常开发的经验,给出你关于Vue/Axios - 使用 url 中的表单数据修补请求?的解决方法建议,希望对你解决Vue/Axios - 使用 url 中的表单数据修补请求?有所启发或帮助;

我绝对是 vue/axios/express 等方面的初学者。 我尝试构建一个rest API来保存客户信息。

一个客户有 2 个值。一个名称和一个网站名称。 一切都按预期进行,但我无法更新客户

我想问题是我使用网站名称来查找/删除/更新这样的客户:

// express controller : 
    update : async (req,res) => {
            let customer = await CustomerModel.findOne({website: req.params.website})
            if (req.body.website) {
                customer.website = req.body.website
            }
            if (req.body.name) {
                customer.name = req.body.name
            }
            let savedCustomer = await customer.save()
            res.send(savedCustomer)
    },// route
router.patch('/customer/:website',CustomerController.update) 
// vue/axios : 

// template 
<template>
  <div class="content-container pl-15 pr-15" >
    <Customer 
        v-for="customer in customers" 
        v-bind:key="customer._ID" 
        v-bind:customer="customer"
        @on-update-customer="updateCustomer(customer.website,customer.name)"
    />
  </div>
</template>

// method
updateCustomer : function(website,customername) {
   axios
      .patch('http://localhost:3000/API/customer/' + website,{
             name : customername,website : website
      })
},

问题是,当我更改网站名称时,axios 会使用更新后的值(不存在)调用 url?

Vue/Axios - 使用 url 中的表单数据修补请求?

子组件:

<template>
    <div class="customer mb-15 pt-10 pb-10 pl-10 pr-10">
            <div class="customer-header">
                <div class="customer-infos">
                    <div class="customer-name mr-15">
                        <small>Kunde:</small>
                        <input
                            type="text"
                            v-model="customer.name"
                        />
                    </div>
                    <div class="customer-website mr-15">
                        <small>Webseite:</small>
                        <input 
                            type="text"
                            v-model="customer.website"
                        />
                    </div>
                </div>
                <div class="customer-actions pl-15">
                    <span class="mr-10">
                        {{contentList.length > 1 ? contentList.length + ' Inhalte' : contentList.length + ' Inhalt' }} 
                    </span>
                    <i 
                        :class="['fas',isHIDden ? 'fa-arrow-circle-down show' : 'fa-arrow-circle-up' ]" 
                        Title="Zeige Inhalte"
                        @click="isHIDden = !isHIDden"
                    />
                    <i 
                        class="far fa-save" 
                        Title="Kundendaten speichern"
                        @click="$emit('on-update-customer')"
                    />
                    <i 
                        class="fas fa-minus-circle remove"
                        Title="Kunde löschen"
                        @click="$emit('on-delete-customer')"
                    />
                </div>
            </div>
            ........

有什么办法可以解决吗? Axios 补丁请求应该使用 url 中的“旧”网站名称,但将其更新为新的。

解决方法

您必须将原始网站名称存储在单独的属性中。或者理想情况下,这将是一个 id。

首次从服务器检索网站名称时,将其存储两次。例如:

组件

data: () => ({
  customer: {
    name: '',website: '',websiteOld: ''
  }
}),created() {
  axios.get(...).then(customer => {
    this.customer = {
      name: customer.name,website: customer.website,websiteOld: customer.website
    }
  });
}

调整您的事件处理程序:

组件

@on-update-customer="updateCustomer(customer)"  
updateCustomer : function(customer) {
  axios.patch('http://localhost:3000/api/customer/' + customer.websiteOld,customer) 
},

大佬总结

以上是大佬教程为你收集整理的Vue/Axios - 使用 url 中的表单数据修补请求?全部内容,希望文章能够帮你解决Vue/Axios - 使用 url 中的表单数据修补请求?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: