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 相关文章推荐
Use Word to Search for Files
Jun 15 Javascript
一个js拖拽的效果类和dom-drag.js浅析
Jul 17 Javascript
jquery多行滚动/向左或向上滚动/响应鼠标实现思路及代码
Jan 23 Javascript
Javascript WebSocket使用实例介绍(简明入门教程)
Apr 16 Javascript
浅谈JavaScript中的Math.atan()方法的使用
Jun 14 Javascript
AngularJS实现与Java Web服务器交互操作示例【附demo源码下载】
Nov 02 Javascript
详解react如何在组件中获取路由参数
Jun 15 Javascript
Vue cli+mui 区域滚动的实例代码
Jan 25 Javascript
给localStorage设置一个过期时间的方法分享
Nov 06 Javascript
微信小程序生成分享海报方法(附带二维码生成)
Mar 29 Javascript
layer ui 导入文件之前传入数据的实例
Sep 23 Javascript
react使用antd表单赋值,用于修改弹框的操作
Oct 29 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循环结构实例讲解
2014/02/10 PHP
php中mkdir函数用法实例分析
2014/11/15 PHP
php实现的用户查询类实例
2015/06/18 PHP
php如何修改SESSION的生存存储时间的实例代码
2017/07/05 PHP
Javascript 入门基础学习
2010/03/10 Javascript
js location.replace与location.reload的区别
2010/09/08 Javascript
细说javascript函数从函数的构成开始
2013/08/29 Javascript
js转义字符介绍
2013/11/05 Javascript
编写自己的jQuery提示框(Tip)插件
2015/02/05 Javascript
JavaScript使用concat连接数组的方法
2015/04/06 Javascript
angularJS与bootstrap结合实现动态加载弹出提示内容
2015/10/16 Javascript
全面解析Bootstrap表单使用方法(表单控件状态)
2015/11/24 Javascript
Bootstrap教程JS插件弹出框学习笔记分享
2016/05/17 Javascript
JS动态给对象添加事件的简单方法
2016/07/19 Javascript
Vue.js实战之组件之间的数据传递
2017/04/01 Javascript
js自定义弹框插件的封装
2020/08/24 Javascript
Webpack性能优化 DLL 用法详解
2017/08/10 Javascript
Vue 刷新当前路由的实现代码
2019/09/26 Javascript
vue实现手机端省市区区域选择
2019/09/27 Javascript
Python中的魔法方法深入理解
2014/07/09 Python
Python爬虫抓取手机APP的传输数据
2016/01/22 Python
关于tensorflow的几种参数初始化方法小结
2020/01/04 Python
python numpy--数组的组合和分割实例
2020/02/24 Python
利用pandas向一个csv文件追加写入数据的实现示例
2020/04/23 Python
python palywright库基本使用
2021/01/21 Python
html5 canvas 简单画板实现代码
2012/01/05 HTML / CSS
mysql_pconnect()和mysql_connect()有什么区别
2012/05/25 面试题
会计专业大学生求职信范文
2014/01/28 职场文书
货车司机岗位职责
2014/03/18 职场文书
环保口号大全
2014/06/12 职场文书
学校门卫岗位职责范本
2014/06/30 职场文书
幼儿园户外活动总结
2014/07/04 职场文书
党员群众路线整改措施及今后努力方向
2014/10/28 职场文书
2015元旦晚会主持人开场白+结束语
2014/12/14 职场文书
IDEA使用SpringAssistant插件创建SpringCloud项目
2021/06/23 Java/Android
学习nginx基础知识
2021/09/04 Servers