首页 > web前端 > js教程 > 正文

在Vue中如何创建组件

亚连
发布: 2018-06-05 09:45:41
原创
2710人浏览过

vue 创建组件的方法有哪些呢?下面我就为大家分享一篇vue 创建组件的两种方法小结,具有很好的参考价值,希望对大家有所帮助。

创建组件的两种方法小结

1.全局注册

2.局部注册

var child=Vue.extend({})
var parent=Vue.extend({})
登录后复制

立即学习前端免费学习笔记(深入)”;

Vue.extend() 全局方法 生成构造器,创建子类

使用基础 Vue 构造器,创建一个“子类”。

这样写非常繁琐。于是vue进行了简化

使用Vue.component()直接创建和注册组件:

Vue.component(id,options) 全局方法 用来注册全局组件

id 是string类型,即是注册组件的名称

options 是个对象

// 全局注册,my-component1是标签名称
Vue.component('my-component1',{
 template: '<p>This is the first component!</p>'
})
var vm1 = new Vue({
 el: '#app1'
})
登录后复制

立即学习前端免费学习笔记(深入)”;

Vue.component()的第1个参数是标签名称,第2个参数是一个选项对象,使用选项对象的template属性定义组件模板。

使用这种方式,Vue在背后会自动地调用Vue.extend()。

在选项对象的components属性中实现局部注册:

var vm2 = new Vue({
 el: '#app2',
 components: {
  // 局部注册,my-component2是标签名称
  'my-component2': {
   template: '<p>This is the second component!</p>'
  },
  // 局部注册,my-component3是标签名称
  'my-component3': {
   template: '<p>This is the third component!</p>'
  }
 }
})
登录后复制

立即学习前端免费学习笔记(深入)”;

==局部注册都放在选项对象中创建==

注意:这里是components,里面可以定义多个组件。

简化后是这样的写法

<body>
 <p id='box'>  
  <parent>  
  </parent>
 </p>
 <script src='js/vue.js'></script>
 <script>
  Vue.component('parent',{
   template:`<p><h1>我是父组件</h1><child></child></p>`,
    components:{
    'child':{
     template:`<h1>我是子组件</h1>`
    }
   }
  })
  new Vue({
   el:'#box'
  })
 </script>
</body>
登录后复制

立即学习前端免费学习笔记(深入)”;

注册一个parent的父组件。然后在父组件的选项对象中注册一个child的子组件。将子组件child的标签写到父组件parent的template里面。

页面上的样式结构就是

<p>
 <h1>我是父组件</h1>
 <h1>我是子组件</h1>
</p>
登录后复制

立即学习前端免费学习笔记(深入)”;

注意:用局部注册的子组件不能单独直接使用!

标签挂在p里,会报错

<p id='box'>  
 <child></child>
</p>
登录后复制

立即学习前端免费学习笔记(深入)”;

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在angular中基于ng-alain如何定义自己的select组件?

在vue中如何实现watch监听对象及对应值的变化

如何解决Vue不能检测数组或对象变动方面问题?

立即学习前端免费学习笔记(深入)”;

以上就是在Vue中如何创建组件的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号