Vue 如何显示来自后端的响应 API
Vue how to display response from backend API
很抱歉提出这样的菜鸟问题,但我已经放弃了。我在下面的代码中创建了一个 POST 请求到应用程序的 BE 部分 - 用户提供输入 (productCodes
) 并按下提交按钮。该部分运行良好,Vue 向 BE 发送请求,但在响应中 FE 应该收到 JSON 结果:{ id: 1234 }
如何获得此响应并将其显示在应用程序中?我有以下内容:
imports.js
const createProductsRequest = (self, products) => {
const jwtToken = self.$store.state.idToken;
const payload = JSON.stringify({ product_codes: products['product_codes'].split(',') })
return axios
.post(`/api/v1/imports/products/`, payload,{
headers: {
Authorization: `Bearer ${jwtToken}`,
'Content-Type': 'application/json',
'Accept': 'application/json'
}
})
.then(response => response.data)
};
export {
createProductsRequest
};
sync_product.vue
<script>
import {
createProductsRequest
} from '../../api/imports'
import ModalController from '../general/modal_controller'
export default {
name: 'BackboneSyncProducts',
data() {
return {
styleCodes: [],
}
},
computed: {
productsToSyncAmount () {
return this.styleCodes.length
},
},
methods: {
async syncProducts() {
let confirmationText = `Do you want to ${this.productsToSyncAmount} sync products?`
if (this.productsToSyncAmount === 0) {
ModalController.showToast('', 'Type product codes for sync first, please!', 'warning')
}
else if (await ModalController.showConfirmation('Confirmation', confirmationText)) {
try {
ModalController.showLoader()
await createProductsRequest(this, this.styleCodes)
const successMessage = `${this.productsToSyncAmount} products have been queued for sync`
await ModalController.showToast('', successMessage)
} catch (data) {
const errorMessage = `Error occurred during queueing products to sync - `
ModalController.showToast('', errorMessage + data?.message, 'error')
} finally {
this.styleCodes = []
ModalController.hideLoader()
}
}
},
}
}
</script>
我只有这些。
而不是在未获得 return 值的情况下调用您的请求:
await createProductsRequest(this, this.styleCodes)
您可以获得 return 值,这是请求的结果:
const data = await createProductsRequest(this, this.styleCodes)
通过这样做,数据必须包含请求的结果,正如您提到的 { id: 1234 }
。
--
如果你想在你的组件中使用这个结果,你可以在 data()
中创建一个反应值
data() {
return {
styleCodes: [],
data: null
}
},
并像这样存储结果:
this.data = await createProductsRequest(this, this.styleCodes)
这样您就可以在您的模板中显示它,例如:
<template>
<!-- There is a v-if because before doing the request, data is null -->
<div v-if="data">{{ data.id }}</div>
</template>
很抱歉提出这样的菜鸟问题,但我已经放弃了。我在下面的代码中创建了一个 POST 请求到应用程序的 BE 部分 - 用户提供输入 (productCodes
) 并按下提交按钮。该部分运行良好,Vue 向 BE 发送请求,但在响应中 FE 应该收到 JSON 结果:{ id: 1234 }
如何获得此响应并将其显示在应用程序中?我有以下内容:
imports.js
const createProductsRequest = (self, products) => {
const jwtToken = self.$store.state.idToken;
const payload = JSON.stringify({ product_codes: products['product_codes'].split(',') })
return axios
.post(`/api/v1/imports/products/`, payload,{
headers: {
Authorization: `Bearer ${jwtToken}`,
'Content-Type': 'application/json',
'Accept': 'application/json'
}
})
.then(response => response.data)
};
export {
createProductsRequest
};
sync_product.vue
<script>
import {
createProductsRequest
} from '../../api/imports'
import ModalController from '../general/modal_controller'
export default {
name: 'BackboneSyncProducts',
data() {
return {
styleCodes: [],
}
},
computed: {
productsToSyncAmount () {
return this.styleCodes.length
},
},
methods: {
async syncProducts() {
let confirmationText = `Do you want to ${this.productsToSyncAmount} sync products?`
if (this.productsToSyncAmount === 0) {
ModalController.showToast('', 'Type product codes for sync first, please!', 'warning')
}
else if (await ModalController.showConfirmation('Confirmation', confirmationText)) {
try {
ModalController.showLoader()
await createProductsRequest(this, this.styleCodes)
const successMessage = `${this.productsToSyncAmount} products have been queued for sync`
await ModalController.showToast('', successMessage)
} catch (data) {
const errorMessage = `Error occurred during queueing products to sync - `
ModalController.showToast('', errorMessage + data?.message, 'error')
} finally {
this.styleCodes = []
ModalController.hideLoader()
}
}
},
}
}
</script>
我只有这些。
而不是在未获得 return 值的情况下调用您的请求:
await createProductsRequest(this, this.styleCodes)
您可以获得 return 值,这是请求的结果:
const data = await createProductsRequest(this, this.styleCodes)
通过这样做,数据必须包含请求的结果,正如您提到的 { id: 1234 }
。
--
如果你想在你的组件中使用这个结果,你可以在 data()
data() {
return {
styleCodes: [],
data: null
}
},
并像这样存储结果:
this.data = await createProductsRequest(this, this.styleCodes)
这样您就可以在您的模板中显示它,例如:
<template>
<!-- There is a v-if because before doing the request, data is null -->
<div v-if="data">{{ data.id }}</div>
</template>