Vue 创建组件的两种方法小结(必看)


Posted in Javascript onFebruary 23, 2018

创建组件的两种方法小结

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: '<div>This is the first component!</div>'
})
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: '<div>This is the second component!</div>'
  },
  // 局部注册,my-component3是标签名称
  'my-component3': {
   template: '<div>This is the third component!</div>'
  }
 }
})

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

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

简化后是这样的写法

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

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

页面上的样式结构就是

<div>
 <h1>我是父组件</h1>
 <h1>我是子组件</h1>
</div>

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

标签挂在div里,会报错

<div id='box'>  
 <child></child>
</div>

结果会报错。

以上这篇Vue 创建组件的两种方法小结(必看)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript事件问题
Sep 05 Javascript
JavaScript 笔记二 Array和Date对象方法
May 22 Javascript
jQuery关于导航条背景切换效果实现示例
Sep 04 Javascript
js对象内部访问this修饰的成员函数示例
Apr 27 Javascript
使用jquery实现放大镜效果
Sep 02 Javascript
jQuery使用toggleClass方法动态添加删除Class样式的方法
Mar 26 Javascript
快速获取/设置iframe内对象元素的几种js实现方法
May 20 Javascript
window.close(); 关闭浏览器窗口js代码的总结介绍
Jul 14 Javascript
jQuery制作图片旋转效果
Feb 02 Javascript
详解动画插件wow.js的使用方法
Sep 13 Javascript
vue 音乐App QQ音乐搜索列表最新接口跨域设置方法
Sep 25 Javascript
微信小程序云开发之新手环境配置
May 16 Javascript
Vue-cli Eslint在vscode里代码自动格式化的方法
Feb 23 #Javascript
ES6下子组件调用父组件的方法(推荐)
Feb 23 #Javascript
angular动态表单制作
Feb 23 #Javascript
angularjs中$http异步上传Excel文件方法
Feb 23 #Javascript
浅谈vuejs实现数据驱动视图原理
Feb 23 #Javascript
Vue父组件调用子组件事件方法
Feb 23 #Javascript
vue实现密码显示隐藏切换功能
Feb 23 #Javascript
You might like
PHP使用array_merge重新排列数组下标的方法
2015/07/22 PHP
CI框架出现mysql数据库连接资源无法释放的解决方法
2016/05/17 PHP
PHP mongodb操作类定义与用法示例【适合mongodb2.x和mongodb3.x】
2018/06/16 PHP
php实现的支付宝网页支付功能示例【基于TP5框架】
2019/09/16 PHP
jQuery 操作下拉列表框实现代码
2010/02/22 Javascript
JS运行耗时操作的延时显示方法
2010/11/19 Javascript
JavaScript实现的字符串replaceAll函数代码分享
2015/04/02 Javascript
JavaScript中length属性的使用方法
2015/06/05 Javascript
基于JS实现移动端访问PC端页面时跳转到对应的移动端网页
2020/12/24 Javascript
Node.js中使用jQuery的做法
2016/08/17 Javascript
JavaScript微信定位功能实现方法
2016/11/29 Javascript
详解ionic本地相册、拍照、裁剪、上传(单图完全版)
2017/10/10 Javascript
详解Node 定时器
2018/02/26 Javascript
node上的redis调用优化示例详解
2018/10/30 Javascript
JS/HTML5游戏常用算法之碰撞检测 像素检测算法实例详解
2018/12/12 Javascript
微信小程序基于picker实现级联菜单
2019/02/15 Javascript
vue实现百度下拉列表交互操作示例
2019/03/12 Javascript
详解Vue 全局变量,局部变量
2019/04/17 Javascript
利用原生JS实现data方法示例代码
2019/05/28 Javascript
详解vuex之store源码简单解析
2019/06/13 Javascript
jquery实现下载图片功能
2019/07/18 jQuery
Python数据类型详解(一)字符串
2016/05/08 Python
使用Django Form解决表单数据无法动态刷新的两种方法
2017/07/14 Python
Python基于ThreadingTCPServer创建多线程代理的方法示例
2018/01/11 Python
Python程序打包工具py2exe和PyInstaller详解
2019/06/28 Python
使用PyWeChatSpy自动回复微信拍一拍功能的实现代码
2020/07/02 Python
护理毕业生自我鉴定
2014/02/11 职场文书
师德师风演讲稿
2014/05/05 职场文书
责任胜于能力演讲稿
2014/05/20 职场文书
拒绝黄毒毒宣传标语
2014/06/26 职场文书
干部年终考核评语
2015/01/04 职场文书
小学生交通安全寄语
2015/02/27 职场文书
联村联户简报
2015/07/21 职场文书
心理健康教育主题班会
2015/08/13 职场文书
2016年小学“我们的节日·中秋节”活动总结
2016/04/05 职场文书
Python实现对齐打印 format函数的用法
2022/04/28 Python