Vue组件化

Vue组件开发

所谓组件化,就是把单个页面拆分成多个组件,每个组件依赖的 CSS、JS、template、等资源放在一起开发和维护

Vue在组件中给了两种组件形式 全局组件 与 局部组件

全局组件

HTML部分:

<body>
  <div id="app">
    <!-- 使用组件 -->
    <Top></Top>
  </div>
</body>

JS部分:

Vue.component("Top",{
  template:`<header>这是{{msg}}</header>`,
  data:function(){
    return{
      msg:"顶部"
    }
  }
})
  new Vue({
    el:"#app",
  })

显示效果:

这是顶部

全局注册语法:Vue.component("组件名",定义组件)
定义组件是一个对象有该组件自己的template、data、mothods等等

注意:
1、组件的data属性是一个函数return的一个对象
2、Vue.componentd(注册组件)一定要在所有new Vue()创建实例前
3、如果单独定义组件要在注册组件之前 先要定义了才可以注册

可以单独定义组件
如下

<body>
  <div id="app">
    <!-- 使用组件 -->
    <Top></Top>
  </div>
</body>

<script src="../../vue.js"></script>
<script>
//定义组件
let Top={
  template:`<header>这是{{msg}}</header>`,
  data:function(){
    return{
      msg:"顶部"
    }
  }
}

//全局注册组件
Vue.component("Top",Top)

  new Vue({
    el:"#app",
  })
</script>

局部组件

HTML部分:

<body>
  <div id="app">
    <!-- 使用组件 -->
    <Top></Top>
    <Bottom></Bottom>
  </div>
</body>

JS部分:

let Top={
  template:`<header>这是{{msg}}</header>`,
  data:function(){
    return{
      msg:"顶部"
    }
  }
}

Vue.component("Top",Top)

let Bottom={
  template:`<header>这是{{msg}}</header>`,
  data:function(){
    return{
      msg:"底部"
    }
  }
}
  new Vue({
    el:"#app",
    components:{//注册局部组件
      // "Bottom":Bottom 可简写为Bottom
      Bottom
    }
  })

显示效果:

这是顶部
这是底部

全局组件与局部组件的区别

局部组件只能在他所在的new Vue()的实例作用域使用
如bottom就只能在#app中使用 全局组件可以在任何vue 实例作用域中使用
注意 注册组件 Vue.component() 一定要在所有new Vue()之前

组件引用外部模板(两种)

使用外部模板的好处 可以提高复用性

第一种:
HTML部分:

<body>
  <div id="app">
    <!-- 使用组件 -->
    <Top></Top>
    <Outside></Outside>
    <Bottom></Bottom>
  </div>
</body>

<!-- 外部模板 -->
<template id="outside">
  <div>
      这是{{msg3}}模板
  </div>
</template>

JS部分:

//定义组件
let Outside = {
  template:"#outside",//选择外部模板
  data:function(){
    return{
      msg3:"外部"
    }
  }
}
//全局注册组件
Vue.component("Outside",Outside)


let Top={
  template:`<header>这是{{msg}}</header>`,
  data:function(){
    return{
      msg:"顶部"
    }
  }
}

Vue.component("Top",Top)

let Bottom={
  template:`<header>这是{{msg}}</header>`,
  data:function(){
    return{
      msg:"底部"
    }
  }
}
  new Vue({
    el:"#app",
    components:{//注册组件
      // "Bottom":Bottom 可简写为Bottom
      Bottom
    }
  })

显示效果:

这是顶部
这是外部模板
这是底部

这里我把外部组件以全局的方式注册了组件 当然也可以用局部的方式来注册组件

第二种:
将第一种HTML中的

<template id="outside">
  <div>
      这是{{msg3}}模板
  </div>
</template>

变更为

<script type="x-template" id="outside">
    <div>
        这是{{msg3}}模板
    </div>
</script>

其余不变也能达到同样的目的

显示效果:

这是顶部
这是外部模板
这是底部

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 认识组件 组件化开发: ​ 将一个完成的页面,划分成一个个的组件,最终由一个个组件来完成整个页面你的开发,这个...
    cj_jax阅读 1,553评论 0 1
  • Vue 组件官网:https://cn.vuejs.org/v2/guide/components.html 组件...
    璎珞纨澜阅读 3,262评论 0 1
  • 组件其实就是一个拥有样式、动画、js逻辑、HTML结构的综合块。前端组件化确实让大的前端团队更高效的开发前端项目。...
    IT老马阅读 4,223评论 0 1
  • 使用 vue-cli 创建模板项目 1、说明 1)vue-cli 是 vue 官方提供的脚手架工具2)github...
    qianxun0921阅读 3,954评论 0 0
  • 使用 vue-cli 创建模板项目 vue-cli 是 vue 官方提供的脚手架工具 github: https:...
    leofight阅读 1,837评论 0 1

友情链接更多精彩内容