vue data有值,但是页面{{}} 取不到值的解决
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要介绍了vue data有值,页面{{}} 取不到值的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随长沙网络推广过来看看吧
我的问题出在js引入的顺序不对,导致不能正常显示vue中的值
正确的顺序应该是
先引入vue的js--------html代码-----引入自己写的js
补充知识vue中子组件的created、mounted生命周期钩子中获取不到props中的值问题
父子组件通信
这个很简单,父组件中使用v-bind绑定传送,子组件使用props接收即可 。
例如在父组件中
<template> <div> <div :Data="Data"></div> </div> </template>
<script> data(){ return { Data: [10,20,30] } }, </script>
子组件中
export default{ props:{ type:Array, default(){ return [] } } }
这种情况下你的Data值是固定的,子组件的 methods 中想要取到props中的值,直接使用 this.chartData 即可 。
有的情况下,你的Data 里面的值并不是固定的,而是动态获取的,这种情况下,你会发现 methods 中是取不到你的 Data 的,或者取到的一直是默认值。
解决办法
这种情况我是使用watch处理
监听 Data 的值,当它由空转变时就会触发,这时候就能取到了,拿到值后要做的处理方法也需要在 watch 里面执行。
export default { props: ['Data'], data(){ return { cData: [] } }, watch: { //正确给 Data 赋值的 方法 chartData: function(newVal,oldVal){ this.cData = newVal; //newVal即是chartData newVa l&& this.draw(); //newVal存在的话执行draw函数 } }, methods: { draw(){ //执行其他逻辑 } }, mounted() { //在created、mounted这样的生命周期, 给 this.Data赋值会失败,错误赋值方法 } }
//
出现这种情况的原因, 因为父组件中要传递的 props 属性 是通过 发生ajax请求回来的, 请求的这个过程是需要时间的,子组件的渲染要快于ajax请求过程,所以此时 created 、 mounted 这样的只会执行一次的生命周期钩子,已经执行了, props 还没有流进来(子组件),所以只能拿到默认值。
以上这篇vue data有值,页面{{}} 取不到值的解决就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
上一篇:解决Vue大括号字符换行踩的坑
下一篇:vue 防止页面加载时看到花括号的解决操作
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指