vue路由跳转时出现 TypeError: Cannot read property ‘_c‘ of undefined

vue路由跳转时出现 TypeError: Cannot read property ‘_c’ of undefined
在这里插入图片描述
启动项目并点击跳转路由,出现上边的错误,在网上找了蛮久,发现各种解答都有。经过多种尝试,发现代码写错了。网上各种改配置,都不适用,所以决定贴出来。

对应页面

<template>
    <div>
     <el-form ref="form" :model="form" label-width="80px">
        <el-form-item label="活动名称">
            <el-input v-model="form.name"></el-input>
        </el-form-item>
        <el-form-item label="活动区域">
            <el-select v-model="form.region" placeholder="请选择活动区域">
            <el-option label="区域一" value="shanghai"></el-option>
            <el-option label="区域二" value="beijing"></el-option>
            </el-select>
        </el-form-item>
        <el-form-item label="活动形式">
            <el-input type="textarea" v-model="form.desc"></el-input>
        </el-form-item>
        <el-form-item>
            <el-button type="primary" @click="onSubmit">立即创建</el-button>
            <el-button>取消</el-button>
        </el-form-item>
    </el-form>      
    </div>    
</template>
<style scoped>
</style>

<script>
export default {
  name: 'test-element',
  data () {
    return {
      formTest: true
    }
  }
}
</script>

路由

<router-link :to="{path: '/test'}">ElementUi表单测试</router-link>
  {
      path: '/test',
      name: 'TestElement',
      components: TestElement
    },

乍一看都没有问题,仔细排查时才发现这里router对应文件中 components错误,这里应该是单个路由,所以应该是 component 而不是 components。

果觉着不错,可以关注我的公众号
lovejsandcss

这个错误通常在使用Vue.js中遇到,当你尝试访问一个未定义或为`null`的数据属性出现。`TypeError: Cannot read properties of undefined (reading 'query')`表明你在某个组件或者方法中尝试访问`query`属性,但这个属性在当前上下文中并未被初始化或者赋值。 可能是以下几个原因导致的: 1. **数据绑定错误**:如果你在模板中使用`v-bind:query`,可能传递给它的值是undefined。检查`this.query`是否已正确设置。 ```html <template> <div v-bind:query="getDataFromAPI"></div> </template> <script> export default { data() { return { query: null, // 初始化为 null }; }, methods: { getDataFromAPI() { /* ... */ } }, mounted() { this.getDataFromAPI(); // 如果没有立即获取数据,可能会先报错 } } </script> ``` 2. **异步操作**:在组件生命周期钩子(如`mounted`)中,如果查询数据依赖于异步操作(如`axios`或`fetch`),确保这些操作在访问数据之前完成。 3. **组件状态管理**:在Vuex等状态管理库中,确保你正确地从store中获取`query`。 4. **路由参数**:在路由跳转,可能需要检查当前路由的动态参数是否正确设置。 修复这个问题的方法通常是检查代码中的错误源头,初始化可能为undefined的变量,并处理可能出现的情况,例如添加`?.`运算符来防止直接访问: ```javascript <template> <div>{{ query?.someProperty }}</div> </template> ... getDataFromAPI() { this.query = await yourDataPromise; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值