Vue学习之组件用法实例详解


Posted in Javascript onJanuary 06, 2020

本文实例讲述了Vue学习之组件用法。分享给大家供大家参考,具体如下:

Vue中的模块化、可重用代码块将页面细分为一个个功能组件,而且组件之间可以嵌套。组件分为全局组件与局部组件,局部组件在实例中进行注册,并且只可以应用于该实例中。

1、 组件的使用流程:

//1、创建组件构造器
    let overallDiv=Vue.extend({
      template:`
        <div>
          <p>这是一个全局组件div</p>
        </div>
      `
    });
  //2、注册全局组件
    Vue.component('overall-div',overallDiv);
  //3、实例化,组件只有在实例化的div内才能使用,不可以直接在页面中使用
    let vue=new Vue({
      el:'#app',
      data:{},
    //在实例内注册局部组件,其创建与注册可以合为一步来写
    components:{
      'local-div':{
        template:
          ` <div>
              <p>这是一个局部组件div</p>
           </div>
          `
      }
    },
    methods:{
    }
    });

在HTML页面实例化的div中使用组件:

<div id="app">
    <local-div></local-div>
    <overall-div></overall-div>
  </div>

Vue学习之组件用法实例详解

注意:一些HTML标签对放入其中的标签有限制,这时需要通过is属性将组件转化为你要放入的组件,例如<ul>标签下只能放<li>,这时,你可以使用<li is="my-component">,这样就相当于放入了<my-component>标签。

2、template模板

组件的模板除了在js中创建外,还可以使用页面中的template创建模板,注意页面中的模板只能有一个根元素,如有多个元素需要包含在一个div内,例如页面body中的模板:

<template id="myTmp">
    <div>
      <p>这是页面中的模板</p>
    </div>
  </template>

在js中通过id号注册模板。

Vue.component('my-tmp',{
    template:'#myTmp'
  });

3、组件的data

在组件中使用data必须以函数的形式返回,如果以属性值的形式存在,所有的组件会共享一个属性值,更改其中一个,所有的组件都会收到影响。例如一个统计被点击次数的组件:

<template id="myBtn">
    <div>
      <button @click="count++">按钮被点击{{count}}次</button>
    </div>
  </template>
Vue.component('my-btn',{
    template:'#myBtn',
    data () {    //以函数返回的方式定义组件使用的data
      return {
        count:0
      };
    }
  });   
  <div id="app">
    <my-btn></my-btn>
    <my-btn></my-btn>
  </div>

在页面中分别点击两个按钮,两个按钮组件的count分别计数,不会互相干扰:

Vue学习之组件用法实例详解

4、父子组件

先创建子组件,然后再父组件内进行注册,就可以在父组件的模板内使用子组件,然后再注册父组件,这样就可以在外部调用包含子组件的父组件了,外部直接使用父组件接口,而不需要知道内部子组件的实现

注意在外部不能直接使用子组件,因为它只在父组件内进行了注册,外部看不到子组件

let child1=Vue.extend({
    template:`<div>这是子组件1</div>`
  });
  let child2=Vue.extend({
    template:`<div>这是子组件2</div>`
  });
  Vue.component('parent',{
    components:{
      'c1':child1,
      'c2':child2
    },
    //在父组件内调用子组件
    template:`<div>父组件<c1></c1><c2></c2></div>`
  });
  <div id="app">
    <parent></parent>
  </div>

结果如图:

Vue学习之组件用法实例详解

5、插槽slot

像生活中的容器一样,slot允许向其中插入标签、组件等内容,而在外部提供一个框子包装起来。slot分为匿名插槽与实名插槽,匿名插槽可以向其中插入任何类型的内容。

实名slot可以将内容插入指定的插槽内,就像一台电脑的主板,cpu、内存条分别有自己对应的插槽,实名插槽在模板中通过name属性规定插槽的名字,在使用时,通过标签的slot属性指定对应的name,可以将标签插入指定的插槽。

匿名插槽

<!--匿名插槽-->
  <template id="anonymousDiv">
    <div style="width: 20%;">
      <h3>这是插槽头部</h3>
      <slot>插槽默认显示内容</slot>
      <hr/>
      <p>插槽尾部</p>
    </div>
  </template>
  let vue2=new Vue({
    el:'#app2',
    data:{
    },
    components:{
     //绑定匿名插槽
     'anonymous-slot':{
       template:'#anonymousDiv'
     },
     //绑定实名插槽
     'realname-slot':{
       template:'#realnameDiv'
     }
    }
  });

向cpu插槽内插入内容:

<div id="app2">
    <anonymous-slot>
      <p>向插槽中插入一段文字</p>
    </anonymous-slot>
  </div>

插槽未放入内容时:插入一段文字:

Vue学习之组件用法实例详解

实名插槽

<template id="realnameDiv">
<div>
  <h3>实名插槽头部</h3>
  <slot name="cpu">这是cpu插槽</slot>
  <slot name="memery">这是内存条插槽</slot>
  <slot name="HardDisk">这是硬盘插槽</slot>
</div>
</template>
<realname-slot>
  <p slot="cpu">Intel Core i5</p>
</realname-slot>

结果:cpu放入指定插槽,而其他插槽未受影响:

Vue学习之组件用法实例详解

希望本文所述对大家vue.js程序设计有所帮助。

Javascript 相关文章推荐
$.ajax json数据传递方法
Nov 19 Javascript
Jquery弹出窗口插件 LeanModal的使用方法
Mar 10 Javascript
基于jquery完美拖拽,可返回拖动轨迹
Mar 29 Javascript
输入自动提示搜索提示功能的javascript:sugggestion.js
Sep 02 Javascript
jquery实现实时改变网页字体大小、字体背景色和颜色的方法
Aug 05 Javascript
vue使用watch 观察路由变化,重新获取内容
Mar 08 Javascript
详解Vue.js搭建路由报错 router.map is not a function
Jun 27 Javascript
webstrom Debug 调试vue项目的方法步骤
Jul 17 Javascript
koa大型web项目中使用路由装饰器的方法示例
Apr 02 Javascript
js图片查看器插件用法示例
Jun 22 Javascript
微信小程序:报错(in promise) MiniProgramError
Oct 30 Javascript
vue实现滑动解锁功能
Mar 03 Vue.js
Vue+abp微信扫码登录的实现代码示例
Jan 06 #Javascript
Vue学习之axios的使用方法实例分析
Jan 06 #Javascript
vue 微信扫码登录(自定义样式)
Jan 06 #Javascript
React学习之JSX与react事件实例分析
Jan 06 #Javascript
vue学习之Vue-Router用法实例分析
Jan 06 #Javascript
借助云开发实现小程序短信验证码的发送
Jan 06 #Javascript
React学习之受控组件与数据共享实例分析
Jan 06 #Javascript
You might like
php实现把数组按指定的个数分隔
2014/02/17 PHP
解密ThinkPHP3.1.2版本之独立分组功能应用
2014/06/19 PHP
PHP实现全角字符转为半角方法汇总
2015/07/09 PHP
laravel model 两表联查示例
2019/10/24 PHP
Javascript 面向对象编程(一) 封装
2011/08/28 Javascript
JS加jquery简单实现标签元素的显示或隐藏
2013/09/23 Javascript
js有序数组的连接问题
2013/10/01 Javascript
jQuery插件简单实现方法
2015/07/18 Javascript
jQuery实现弹出带遮罩层的居中浮动窗口效果
2016/09/12 Javascript
Vue.js一个文件对应一个组件实践
2016/10/27 Javascript
详谈Angular路由与Nodejs路由的区别
2017/03/05 NodeJs
使用vue.js编写蓝色拼图小游戏
2017/03/17 Javascript
vue2.0实战之使用vue-cli搭建项目(2)
2017/03/27 Javascript
jquery replace方法去空格
2017/05/08 jQuery
jQuery模拟爆炸倒计时功能实例代码
2017/08/21 jQuery
mui框架移动开发初体验详解
2017/10/11 Javascript
详解使用webpack构建多页面应用
2017/12/21 Javascript
vue axios 简单封装以及思考
2018/10/09 Javascript
Vue表单之v-model绑定下拉列表功能
2019/05/14 Javascript
一文了解vue-router之hash模式和history模式
2019/05/31 Javascript
python脚本实现查找webshell的方法
2014/07/31 Python
zookeeper python接口实例详解
2018/01/18 Python
python实现人脸识别经典算法(一) 特征脸法
2018/03/13 Python
Python面向对象程序设计之继承与多继承用法分析
2018/07/13 Python
python 从文件夹抽取图片另存的方法
2018/12/04 Python
解决python字典对值(值为列表)赋值出现重复的问题
2019/01/20 Python
Python使用paramiko操作linux的方法讲解
2019/02/25 Python
win8.1安装Python 2.7版环境图文详解
2019/07/01 Python
python解释器pycharm安装及环境变量配置教程图文详解
2020/02/26 Python
Django 权限管理(permissions)与用户组(group)详解
2020/11/30 Python
python爬虫线程池案例详解(梨视频短视频爬取)
2021/02/20 Python
CSS3下的渐变文字效果实现示例
2018/03/02 HTML / CSS
北京SQL新华信咨询
2016/09/30 面试题
感恩主题班会教案
2015/08/12 职场文书
宫崎骏十大动画电影,宫崎骏好看的动画电影排名
2022/03/22 日漫
python疲劳驾驶困倦低头检测功能的实现
2022/04/04 Python