javascript - vue-resource得到数据后,如何修改组件中data的值?
本文介绍了javascript - vue-resource得到数据后,如何修改组件中data的值?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
<div id="app">
<div id="content">
<my-nav></my-nav>
</div>
</div>
//js
var myNav = Vue.extend({
template: '<div>{{msg}}</div>',
data: function () {
return {
msg:'123',
}
},
mounted:function(){
this.getNavname();
},
methods:{
getNavname:function(){
this.$http.get("server/MyServer.ashx")
.then(
function(response){
//获取数据后尝试修改组件中msg的值
this.$set(this.msg,'hello')
//报错:vue.js:1156 Uncaught (in promise) TypeError: Cannot create property 'hello' on string '123'(…)
console.log(response)
},
function(response){
console.log(response)
});
}
}
});
new Vue({
el:'#app',
components:{
'my-nav':myNav
}
})
新手刚入手,求各位大虾指导,告诉我怎么做可以更好。
组件加载正常,也渲染出了123,但是为什么渲染不出修改后的值,获取数据是成功的。
解决方案
为什么不用 this.msg = 'hello' ?
这篇关于javascript - vue-resource得到数据后,如何修改组件中data的值?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文