<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<link href="css/bundle.css" rel="stylesheet">
<style></style>
</head>
<body>
<div id="watch-example">
<p>
Ask a yes/no question:
<input type="text" v-model="question">
</p>
<p>{{answer}}</p>
<img v-if="seen" v-bind:src="imgSrc"/>
</div>
<script src="js/vue.min2.0.js"></script>
<script src="https://unpkg.com/axios@0.12.0/dist/axios.min.js"></script>
<script src="https://unpkg.com/lodash@4.13.1/lodash.min.js"></script>
<script>
var watchExampleVM = new Vue({
el: "#watch-example",
data: {
question: "",
answer: "I cannot give you an answer until you ask a question!",
imgSrc: "",
seen: false
},
watch: {
question: function(newQuestion){
this.answer = "Waiting for you to stop typing...",
this.seen = false,
this.imgSrc = "",
this.getAnswer();
}
},
methods: {
getAnswer: _.debounce(function(){
var vm = this;
if(this.question.indexOf("?") === -1){
vm.answer = "Questions usually contain a question mark:?";
return;
}
vm.answer = "Thinking...";
axios.get("https://yesno.wtf/api").then(function(response){
vm.imgSrc = response.data.image,
vm.seen = true,
vm.answer = _.capitalize(response.data.answer)
}).catch(function(error){
vm.answer = "Error! Could not reach the API." + error
})
},500)
}
});
</script>
</body>
</html>
效果:
原链接:https://cn.vuejs.org/v2/guide/computed.html#观察-Watchers