Vue自定义组件的四种方式示例详解


Posted in Javascript onFebruary 28, 2020

四种组件定义方式都存在以下共性(血泪史)

规则:

1.组件只能有一个根标签

2.记住两个词全局和局部

3.组件名称命名中‘-小写字母'相当于大写英文字母(hello-com 相当于 helloCom)

而对于在HTML中自定义组件的时候有4种写法,不过也只是殊途同归,都是用template属性对应的只有一个根标签的HTML代码。

1.全局组件

定义方式示例:

Vue.component("hello-component",{
  props:["message"],
  template :"<div ><h1>组件定义之全局组件</h1><h4>{{message}}</h4></div>"
});

使用

<hello-component message=" global component"></hello-component>

属性介绍:

Vue.componen()是vue.js内部封装方法
"hello-component" 是使用时候的组件名称
props组件内的属性。供给组件内部传值
template组件内部DOM元素组成

品鉴

全局组件定义方式,是直接给全局对象Vue注册了一个组件。在本页内已挂载Vue 实例的DOM目标元素 都可以使用(区别于局部组件只能是挂载哪一个DOM,哪个才能使用)。

2.局部组件

定义方式示例:

var limitComponent = {
  props:["message"],
  template :"<div><h1>{{message}}</h1><input \
  type='text' v-model='message'></input></div>"
}
new Vue ({
  el : "#app",
  components :{
    "child-component": limitComponent
  }
});

使用

<child-component message = "动态局部组件"></child-component>

属性介绍:

el是 Vue 实例的挂载目标
"components" 是注册仅在其作用域中可用的组件
"child-component"组件的名称(书写规则请上翻再看规则)
limitComponent通过对象方式传递组件

品鉴

  • 你不必把每个组件都注册到全局。你可以通过某个 Vue 实例/组件的实例选项 components 注册仅在其作用域中可用的组件。
  • js中用反斜线“\”'实现字符串换行

3.Script方式注册组件

定义方式示例:

<script type="text/template" id="script-component">
  <div >
    <h2>自定义组件之script方式定义</h2>
    <h4>{{message}}</h4>
  </div>
</script>
<script>
  Vue.component("mymac",{
    props:["message"],
    template:"#script-component"
  })

  var newVue = new Vue({
    el:"#mac",
    data:{
      mydata:"春暖花开"
    }
  });
</script>

使用

<div id="mac" >
  <input type="text" v-model="mydata" />
  <mymac v-bind:message="mydata"></mymac>
</div>

属性介绍:

<script type="text/template" id="script-component">为定义组件的一种写法,type还可以取的值还可以有:

  • text/javascript: 说明这一段脚本语言是javascript。告诉浏览器这一段要按照javascript来解释执行。在ES5之前的type默认值
  • text/ecmascript:JavaScript和ECMAScript是相同的,只是在名称上是不同的。但是对于ecmascript-6而言就可以理解是JS的新语法特性。即HTML5中的默认值
  • application/ecmascript: ie6、7、8都是没法识别里面的js语句的
  • application/javascript: 这个属性在IE8以下的浏览器中无法被识别。
  • text/vbscript: 表示该脚本语言是vb脚本

品鉴

Script定义组件方式笔者觉得就是组件定义方式的另一种写法。优点在于不用写字符串式HTML代码。将<script id="XX">的XX赋值给局部组件或者全局组件都可。

4.<template>创建组件

定义方式示例:

<template id="cc">
  <div >
    <h1>{{message}}</h1>
  </div>
  
</template>
<script>
  Vue.component('templatec',{
    props:["message"],
    template:"#cc"
  })
  new Vue({
    el:"#MyTemp"
  })
</script>

使用

<div id="MyTemp">
  <templatec message ="template组件之Template标签"></templatec>
</div>

属性介绍:

<template> 为HTML5发布后用来声明是“模板元素”的标签。即HTML5之前使用<script type ="text/template">方式声明,而HTML5之后可用<template> 标签

品鉴

<template>定义组件的方式实际是HTML语法升级后的<script type ="text/template">的另一种写法。同script定义组件一样,同样可以配合定义全局/局部组件。

总结

通篇全文,介绍的四种方式。实际上只有两种方式。要不就是全局定义方式,要不就是局部定义方式。另外两种是为了增加代码开发效率将字符串写法换成标签式书写方式。

到此这篇关于Vuejs自定义组件的四种方式的文章就介绍到这了,更多相关vue 自定义组件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
基于jQuery的输入框无值自动显示指定数据的实现代码
Jan 24 Javascript
基于jquery的button默认enter事件(回车事件)。
May 18 Javascript
HTML上传控件取消选择
Mar 06 Javascript
js控制web打印(局部打印)方法整理
May 29 Javascript
JS判断图片是否加载完成方法汇总(最新版)
May 13 Javascript
用js实现简单算法的实例代码
Sep 24 Javascript
学习JavaScript图片预加载模块
Nov 07 Javascript
jQuery简单实现遍历单选框的方法
Mar 06 Javascript
详解React Native网络请求fetch简单封装
Aug 10 Javascript
JavaScript如何实现图片处理与合成
May 29 Javascript
vue3.0 加载json的方法(非ajax)
Oct 26 Javascript
vue实现倒计时功能
Mar 24 Vue.js
Vue.js 中制作自定义选择组件的代码附演示demo
Feb 28 #Javascript
使用vue-cli3+typescript的项目模板创建工程的教程
Feb 28 #Javascript
基于vue-cli3+typescript的tsx开发模板搭建过程分享
Feb 28 #Javascript
vue 中的 render 函数作用详解
Feb 28 #Javascript
微信小程序动态添加和删除组件的现实
Feb 28 #Javascript
浅析Vue 中的 render 函数
Feb 28 #Javascript
微信小程序实现录制、试听、上传音频功能(带波形图)
Feb 27 #Javascript
You might like
第四节--构造函数和析构函数
2006/11/16 PHP
《PHP编程最快明白》第六讲:Mysql数据库操作
2010/11/01 PHP
深入PHP数据缓存的使用说明
2013/05/10 PHP
解析PHP中的正则表达式以及模式匹配
2013/06/19 PHP
详解ThinkPHP3.2.3验证码显示、刷新、校验
2016/12/29 PHP
在php的yii2框架中整合hbase库的方法
2018/09/20 PHP
如何让您的中波更粗更长 - 中波框形天线制作
2021/03/10 无线电
javascript中[]和{}对象使用介绍
2013/03/20 Javascript
解决js图片加载时出现404的问题
2020/11/30 Javascript
JS实现动态生成表格并提交表格数据向后端
2020/11/25 Javascript
JS限定手机版中图片大小随分辨率自动调整的方法
2016/12/05 Javascript
jquery实现刷新随机变化样式特效(tag标签样式)
2017/02/03 Javascript
老生常谈jquery id选择器和class选择器的区别
2017/02/12 Javascript
微信小程序实战之登录页面制作(5)
2020/03/30 Javascript
Nodejs调用WebService的示例代码
2017/09/29 NodeJs
postman+json+springmvc测试批量添加实例
2018/03/31 Javascript
封装Vue Element的table表格组件的示例详解
2020/08/19 Javascript
让你30分钟快速掌握vue3教程
2020/10/26 Javascript
Nuxt.js的路由跳转操作(页面跳转nuxt-link)
2020/11/06 Javascript
Vue使用Proxy代理后仍无法生效的解决
2020/11/13 Javascript
[01:19]2014DOTA2国际邀请赛 采访TITAN战队ohaiyo 能赢DK很幸运
2014/07/12 DOTA
Python3中多线程编程的队列运作示例
2015/04/16 Python
python统计函数库scipy.stats的用法解析
2020/02/25 Python
Python作用域与名字空间原理详解
2020/03/21 Python
浅谈pytorch中torch.max和F.softmax函数的维度解释
2020/06/28 Python
利用纯html5绘制出来的一款非常漂亮的时钟
2015/01/04 HTML / CSS
音乐教学反思
2014/02/02 职场文书
创先争优活动方案
2014/02/12 职场文书
农业开发项目建议书
2014/05/16 职场文书
学风建设演讲稿
2014/09/12 职场文书
单位授权委托书范本
2014/09/26 职场文书
模范教师材料大全
2014/12/16 职场文书
个性与发展自我评价
2015/03/06 职场文书
2015年七夕情人节活动方案
2015/05/06 职场文书
详解Python小数据池和代码块缓存机制
2021/04/07 Python
windows server2008 开启端口的实现方法
2022/06/25 Servers