Vue-Router路由Vue-CLI脚手架和模块化开发 之 在单文件组件项目中定义数据方法和组件之间的相互引用

Posted jiguiyan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue-Router路由Vue-CLI脚手架和模块化开发 之 在单文件组件项目中定义数据方法和组件之间的相互引用相关的知识,希望对你有一定的参考价值。

定义数据

根据上一篇博文配置项目的结构的基础上继续进行优化;

 

技术图片

 

 

 

在app.vue中的导出模块/组件部分设置其属性:

export default{//导出模块/组件
        data(){
            
            return{
                name:perfect,
                count:0
                
            }
        },

在一个template标签中进行调用:

<template>
    <div>
        
        <h2> 欢迎来到perfect*的博客园!!!</h2>
    <h3>{{name}}</h3>
    
    

    
    
</template>

 实现上述定义数据的总代码,只修改了app.vue

技术图片
 1 <template>
 2     <div>
 3         
 4         <h2> 欢迎来到perfect*的博客园!!!</h2>
 5     <h3>{{name}}</h3>
 6     
 7     </div>
 8     
 9 
10     
11     
12 </template>
13 
14 <script>
15     //console.log(‘欢迎来到perfect*的博客园‘)
16     
17     
18     export default{//导出模块/组件
19         data(){
20             
21             return{
22                 name:perfect,
23                 count:0
24                 
25             }
26         }
27         
28         
29     }
30 </script>
31 
32 <style>
33     
34     h2{
35         
36         color: red;
37     }
38 </style>
定义数据

定义方法:

技术图片

 

 在app.vue中定义了一个方法

export default{//导出模块/组件
        data(){
            
            return{
                name:perfect,
                count:0
                
            }
        },
        methods:{
            
            addCount(){
                
                this.count++;
            }
        }
        
        
        
    }

在template中进行调用

<template>
    <div>
        
        <h2> 欢迎来到perfect*的博客园!!!</h2>
    <h3>{{name}}</h3>
   <h4 @click="addCount">{{count}}</h4>
    </div>
    

    
    
</template>

定义方法总的代码:

技术图片
 1 <template>
 2     <div>
 3         
 4         <h2> 欢迎来到perfect*的博客园!!!</h2>
 5     <h3>{{name}}</h3>
 6    <h4 @click="addCount">{{count}}</h4>
 7     </div>
 8     
 9 
10     
11     
12 </template>
13 
14 <script>
15     //console.log(‘欢迎来到perfect*的博客园‘)
16     
17     
18     export default{//导出模块/组件
19         data(){
20             
21             return{
22                 name:perfect,
23                 count:0
24                 
25             }
26         },
27         methods:{
28             
29             addCount(){
30                 
31                 this.count++;
32             }
33         }
34         
35         
36         
37     }
38 </script>
39 
40 <style>
41     
42     h2{
43         
44         color: red;
45     }
46 </style>
定义方法

 

 

定义组件之间的相互引用

 

技术图片

新建一个目录components---->在目录中建一个user.vue

技术图片

user.vue

 1 <template>
 2 <div>
 3 <h2>用户信息</h2>
 4 <h3>{{user}}</h3>
 5 
 6 </div>
 7 </template>
 8 
 9 <script>
10     
11     export default{
12         
13         data(){
14             return{
15                 user:{
16                     
17                     username:perfect*,
18                     password:123
19                 }
20             }
21         }
22     }
23 </script>
24 
25 <style>
26 </style>

 

在app.vue中引入该文件:import+自定义名称+from+自定义路径

import user from ./components/user.vue

 

 

注册组件:

技术图片

components:{//注册组件
            
            user
        }

使用组件:

技术图片

 <user></user><!--使用组件-->

由效果图可以看到“用户信息”字样的样式为红色,而在user.vue中我并没有为它使用样式,所以说明默认使用全局的样式,如果不想使用全局的样式,想使用user.vue中设计的样式,可以加入如下代码:

技术图片

 

 在app.vue

技术图片

 

 

<style scoped="scoped">
    
    h2{
        
        color: red;
    }
</style>

 

技术图片
 1 <template>
 2     <div>
 3         
 4         <h2> 欢迎来到perfect*的博客园!!!</h2>
 5     <h3>{{name}}</h3>
 6    <h4 @click="addCount">{{count}}</h4>
 7    <user></user><!--使用组件-->
 8  
 9     </div>
10     
11 
12     
13     
14 </template>
15 
16 <script>
17     //console.log(‘欢迎来到perfect*的博客园‘)
18     import user from ./components/user.vue
19     
20     
21     export default{//导出模块/组件
22         data(){
23             
24             return{
25                 name:perfect,
26                 count:0
27                 
28             }
29         },
30         methods:{
31             
32             addCount(){
33                 
34                 this.count++;
35             }
36         },
37         components:{//注册组件
38             
39             user
40         }
41         
42         
43         
44     }
45 </script>
46 
47 <style scoped="scoped">
48     
49     h2{
50         
51         color: red;
52     }
53 </style>
在单文件组件项目中定义数据、方法和组件之间的相互引用的总demo

 

以上是关于Vue-Router路由Vue-CLI脚手架和模块化开发 之 在单文件组件项目中定义数据方法和组件之间的相互引用的主要内容,如果未能解决你的问题,请参考以下文章

Vue-Router路由Vue-CLI脚手架和模块化开发 之 在单文件组件项目中定义数据方法和组件之间的相互引用

Vuevue-cli,WebPack,vue-router路由

Vuevue-cli,WebPack,vue-router路由

Vuevue-cli,WebPack,vue-router路由

VUE学习笔记:26.脚手架vue-cli之路由vue-router

vue-router的使用