VueJS api 调用未定义数据
VueJS api call leaving data undefined
我正在学习 VueJS 2.0,我正在连接到一个 API,我希望其中一些数据的值随着输入的变化而变化。以下是使用开发工具的输出内容:
canadianDollar:undefined
europeanEuro:undefined
europeanPound:undefined
usd:"1232"
每当我在 USD 输入字段中输入 1232 时,它都不会 return 任何内容,并将这些属性保留为未定义。这是代码。
new Vue({
el: '#app',
data: {
usd: '',
canadianDollar: '',
europeanPound: '',
europeanEuro: ''
},
// Watch methods
watch: {
usd: function() {
this.convertCurrency()
}
},
// Logic Methods
methods: {
convertCurrency: _.debounce(function() {
var app = this;
if (app.usd.length !== 0) {
// Show that the things are loading in.
app.canadianDollar = 'Searching...'
app.europeanPound = 'Searching...'
app.europeanEuro = 'Searching...'
console.log(app.usd)
axios.get("http://api.fixer.io/latest?base=USD&" + app.usd)
.then(function(response) {
app.canadianDollar = response.data.CAD
app.europeanPound = response.data.GBP
app.europeanEuro = response.data.EUR
})
.catch(function(error){
app.canadianDollar = "ERROR"
app.europeanPound = "ERROR"
app.europeanEuro = "ERROR"
})
}
}, 500)
}
})
和 HTML:
<!DOCTYPE html>
<html>
<head>
<title>Welcome to Vue</title>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" name="" value="" v-model="usd">
<ul>
<li>Canadian Dollar: {{canadianDollar}}</li>
<li>European Pound: {{europeanPound}}</li>
<li>European Euro: {{europeanEuro}}</li>
</ul>
</div>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script src="https://cdn.jsdelivr.net/lodash/4.17.4/lodash.min.js" charset="utf-8"></script>
<script src="index.js" charset="utf-8"></script>
</body>
</html>
当我输入一个数字时,它确实给了我 "Searching" 部分但消失了,什么也没有显示。
...
response.data.rates.CAD;
你有
response.data.CAD;
...
app.canadianDollar = response.data.rates.CAD * app.usd;
我建议更改
then(function(response) {
app.canadianDollar = response.data.CAD
app.europeanPound = response.data.GBP
app.europeanEuro = response.data.EUR
})
到
then(function(response) {
console.log(response);
})
那是你可以看到返回的内容。
另外,axios.get("http://api.fixer.io/latest?base=USD&" + app.usd)
可能应该有一个像 vulue:axios.get("http://api.fixer.io/latest?base=USD&VALUE=" + app.usd)
这样的名字,但是你必须检查他们的 api 才能知道它是什么意思。
我正在学习 VueJS 2.0,我正在连接到一个 API,我希望其中一些数据的值随着输入的变化而变化。以下是使用开发工具的输出内容:
canadianDollar:undefined
europeanEuro:undefined
europeanPound:undefined
usd:"1232"
每当我在 USD 输入字段中输入 1232 时,它都不会 return 任何内容,并将这些属性保留为未定义。这是代码。
new Vue({
el: '#app',
data: {
usd: '',
canadianDollar: '',
europeanPound: '',
europeanEuro: ''
},
// Watch methods
watch: {
usd: function() {
this.convertCurrency()
}
},
// Logic Methods
methods: {
convertCurrency: _.debounce(function() {
var app = this;
if (app.usd.length !== 0) {
// Show that the things are loading in.
app.canadianDollar = 'Searching...'
app.europeanPound = 'Searching...'
app.europeanEuro = 'Searching...'
console.log(app.usd)
axios.get("http://api.fixer.io/latest?base=USD&" + app.usd)
.then(function(response) {
app.canadianDollar = response.data.CAD
app.europeanPound = response.data.GBP
app.europeanEuro = response.data.EUR
})
.catch(function(error){
app.canadianDollar = "ERROR"
app.europeanPound = "ERROR"
app.europeanEuro = "ERROR"
})
}
}, 500)
}
})
和 HTML:
<!DOCTYPE html>
<html>
<head>
<title>Welcome to Vue</title>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<input type="text" name="" value="" v-model="usd">
<ul>
<li>Canadian Dollar: {{canadianDollar}}</li>
<li>European Pound: {{europeanPound}}</li>
<li>European Euro: {{europeanEuro}}</li>
</ul>
</div>
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script src="https://cdn.jsdelivr.net/lodash/4.17.4/lodash.min.js" charset="utf-8"></script>
<script src="index.js" charset="utf-8"></script>
</body>
</html>
当我输入一个数字时,它确实给了我 "Searching" 部分但消失了,什么也没有显示。
...
response.data.rates.CAD;
你有
response.data.CAD;
...
app.canadianDollar = response.data.rates.CAD * app.usd;
我建议更改
then(function(response) {
app.canadianDollar = response.data.CAD
app.europeanPound = response.data.GBP
app.europeanEuro = response.data.EUR
})
到
then(function(response) {
console.log(response);
})
那是你可以看到返回的内容。
另外,axios.get("http://api.fixer.io/latest?base=USD&" + app.usd)
可能应该有一个像 vulue:axios.get("http://api.fixer.io/latest?base=USD&VALUE=" + app.usd)
这样的名字,但是你必须检查他们的 api 才能知道它是什么意思。