温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么深入了解Vue组件的创建和使用

发布时间:2021-12-24 20:43:19 来源:亿速云 阅读:184 作者:柒染 栏目:开发技术

今天就跟大家聊聊有关怎么深入了解Vue组件的创建和使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

    一、什么是组件?

    组件 (Component) 是 Vue.js 最强大的功能之一。组件可以扩展 HTML 元素,封装可重用的代码。在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能。

    二、创建全局组件

    方式一

    1、Vue.extend
       var com1 = Vue.extend({
    // 通过 template 属性,指定了组件要展示的HTML结构
                   template: '<h4>这是使用 Vue.extend 创建的组件</h4>'
                })
    2、Vue.component

    Vue.component(‘组件的名称', 创建出来的组件模板对象) 注册组件

      Vue.component('myCom1', com1)

    注意:如果使用Vue.Component 注册全局组件的时候,组件的名称使用了驼峰命名,则在引用组件的时候需要把大写的驼峰改为小写的字母,同时,两个单词之前,使用 “–” 链接。如果不使用则直接拿名称来使用即可。

    怎么深入了解Vue组件的创建和使用

    方式二

    直接使用Vue.component
    Vue.component('mycom2', {
                    template: '<div><h4>这是直接使用 Vue.component 创建出来的组件</h4>
    <span>123</span></div>'
                })

    示例:

    怎么深入了解Vue组件的创建和使用

    方式三

    1、被控制的 #app 外面,使用 template 元素,定义组件的HTML模板结构。

    <template id="tmpl">
                <div>
                    <h2>这是通过 template 元素,在外部定义的组件结构</h2>
                    <h5>好用,不错!</h5>
                </div>
            </template>

    2、使用id注册组件

       Vue.component('mycom3', {
            template: '#tmpl'
        })

    三、 创建局部组件

    局部组件的创建和全局组件的创建方法一样。唯一区别的是,局部组件是在Vue实例中定义的。

    怎么深入了解Vue组件的创建和使用

    四、组件中的data 和 methods

    1、组件可以拥有自己的数据。

    2、组件中的data 和实例中的data 有点不一样,实例中的data 可以为一个对象。但是组件中的data必须是一个方法。

    3、组件中的data除了是一个方法,还必须返回一个对象。

    4、组件中的data 的使用方式和 实例中的data 使用方式一样。(methods也一样)

    怎么深入了解Vue组件的创建和使用

    五、组件间的通信方式

    怎么深入了解Vue组件的创建和使用

    props/$emit

    父组件A通过props的方式向子组件B传递,B to A 通过在 B 组件中 $emit, A 组件中 v-on 的方式实现。

    子组件:

    <template>
      <div class="hello">
        <ul>
          <li v-for="(user,index) in users" v-bind:key="index">{{ user }}</li>
        </ul>
      </div>
    </template>
    
    <script>
    export default {
      name: "users",
      props: {
        users: {  //父组件中子标签自定义的名字
          type: Array,
          require: true
        }
      }
    }
    </script>
    
    <style scoped>
     li{
       list-style-position: inside;
     }
    </style>

    父组件:

    <template>
      <div id="app">
        <img alt="Vue logo" src="./assets/logo.png">
        <Users v-bind:users="users"> </Users>
      </div>
    </template>
    
    <script>
    import Users from "@/components/users";
    export default {
      name: 'App',
      data(){
        return {
          users: ['西安邮电','西安石油','西北政法','西安工业','西安财经']
        }
      },
      components: {
        Users,
      }
    }
    </script>

    通过事件形式

    子组件

    <template>
      <header>
        <h2 @click="changeTitle">{{ title }}</h2>
      </header>
    </template>
    <script>
    export default {
      name: "Son",
      data(){
        return {
          title: 'Vue.js Demo'
        }
      },
      methods: {
        changeTitle(){
          this.$emit('titleChanged','西安邮电大学');
        }
      }
    }
    </script>
    
    <style scoped>
     h2{
       background-color: greenyellow;
     }
    </style>

    父组件:

    <template>
      <div id="app">
        <Son v-on:titleChanged="updateTitle"></Son>
        <h3>{{ title }}</h3>
      </div>
    </template>
    <script>
    import Son from "@/components/Son";
    export default {
      name: "Father",
      data(){
        return {
          title: '传递的是一个值'
        }
      },
      methods: {
        updateTitle(e){
          this.title = e
        }
      },
      components:{
        Son,
      }
    }
    </script>

    子组件通过events(事件)给父组件发送消息,实际上就是子组件把自己的数据发送到父组件。

    看完上述内容,你们对怎么深入了解Vue组件的创建和使用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    vue
    AI