IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> VUE - 8 - VUE的组件 -> 正文阅读

[JavaScript知识库]VUE - 8 - VUE的组件


本篇图片截图来自尚硅谷:https://www.bilibili.com/video/BV1Zy4y1K7SH?p=53

什么是组件

组件是用来实现局部(特定)功能代码的集合(html、css、js、img、video…),尤其再界面功能很复杂的时候,有代码复用,简化项目编码,提高运行效率作用。

可以看一张很形象的图形解释:
在这里插入图片描述

为什么用组件

因为组件是可复用的 Vue 实例,所以它们与 new Vue 接收相同的选项,例如 data、computed、watch、methods 以及生命周期钩子等。仅有的例外是像 el 这样根实例特有的选项。

为什么选择组件式编程:看两张图吧:
在这里插入图片描述
在这里插入图片描述

组建的基础

要想在项目中使用组件,要分三步实现:创建组件,注册组件,使用组件。

  • 创建组件
    • 使用Vue.extend(options)创建,其中optionsnew Vew(options)时传入的options几乎一样,但是有区别:
      • 不写 el:所有的组件都听从vm的管理,由vm的el决定服务于那个容器。
      • data必须写成函数:避免组件复用时,数据存在引用关系。
      • 可以使用template配置组件结构。
    • 单词语组件名:‘school’
    • 多词语组件名:“my-student” ,但是Vue展示的时候是 <MyStudent>
    • 在脚手架里,多词语组件名:“MyStudent” 。
  • 注册组件:
    • 局部注册:在new Vue(options),给options传入components选项。
    • 全局注册:Vue.component("School",School);
  • 使用组件:
    • 在非单文件组件中只能用: <School></School>
    • 在单文件组件中可以用:<School />

在非单文件中的组件代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Hello Vue</title>
    <link rel="icon" href="../logo.svg">
</head>
<body>
    <div id="root">
        <h1>{{msg}}</h1>
        <hr>
        <!--使用组件-->
        <School></School>
        <hr>       
        学生组件:      
        <my-student></my-student>
        <!-- 重复使用组件 -->
       <my-student></my-student>
    </div> 
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script>
    Vue.config.productionTip=false;
    // 创建Student组件
    const Student=Vue.extend({
    	name:'Student',
        template:`
            <div>
                <p>学生姓名:{{name}}</p>
                <p>学生年龄:{{age}}</p>
                <p>学生性别:{{sex}}</p>
            </div>`,
        data(){
            return{
                name:"张三",
                age:18,
                sex:"男"
            }
        }
    })
    
    // 创建School组件
    const School = Vue.extend({
    	name:'School',
        data(){
            return{
                name:"五道口技术学院",
                add:"北京"
            }
        },
        template:`
        <div>
            <p>学校名字:{{name}}</p>
            <p>学校地址:{{add}}</p>
        </div>
        `
    })
     //注册组件(全局注册)
    Vue.component("School",School);    
    var vm = new Vue({
        el:"#root",
        //注册组件(局部注册)
        components:{
            'my-student':Student,
            //School:School, => School
        },
        data:{
            msg:"hello Vue!" 
        }
    })
</script>
</body>
</html>

效果:
在这里插入图片描述

组件嵌套

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Hello Vue</title>
    <link rel="icon" href="../logo.svg">
</head>
<body>
    <div id="root">
        <h1>{{msg}}</h1>
        <hr>
        <!--使用组件-->
        <School></School>        
    </div> 
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script>
    Vue.config.productionTip=false;
    // 创建Student组件
    const Student=Vue.extend({
        template:`
            <div>
                <p>学生姓名:{{name}}</p>
                <p>学生年龄:{{age}}</p>
                <p>学生性别:{{sex}}</p>
            </div>`,
        data(){
            return{
                name:"张三",
                age:18,
                sex:"男"
            }
        }
    })    
    // 创建School组件
    const School = Vue.extend({
        data(){
            return{
                name:"五道口技术学院",
                add:"北京"
            }
        },
        components:{
            'my-student':Student
        },
        template:`
        <div>
            <p>学校名字:{{name}}</p>
            <p>学校地址:{{add}}</p>
            <hr>       
            学生组件:  
            <!--嵌套组件-->
            <my-student></my-student>
        </div>
        `
    })    
     //注册组件(全局注册)
    Vue.component("School",School);    
    var vm = new Vue({
        el:"#root",
        data:{
            msg:"hello Vue!" 
        }
    })
</script>
</body>
</html>

效果:在这里插入图片描述

关于VueComponent

  • School组件的本质是一个名为VueComponent的构造函数,是Vue.extend生成的。
  • 我们只需要写<School></School> 或者 <School/>Vue解析时会帮我们创建school的实例对象,帮我们执行new VueComponent(options)
  • 依次调用 VueComponent,返回的都是一个全新的VueComponent实例。

扩展

  • data的两种写法:
    • new Vue() 时配置el属性
    • 先创建Vue实例,然后再通过$mount("#root")指定el的值
  • el的两种写法:
    • 对象式
    • 函数式
  • 关于this指向:
    • Vue.extend()配置中:data函数,methods / watch / component 中的函数、钩子函数 ,它们的this都是VueComponent实例对象
    • new Vue() 配置中:data函数,methods / watch / component 中的函数、钩子函数 ,它们的this都是Vue实例对象
  • 一个重要的原则:
    • 由vue管理的函数,一定不要写箭头函数,因为箭头函数没有this,this就不再是Vue实例了。
    • vue管理的函数内部的所有函数一律使用箭头函数,因为箭头函数没有this,this就指向Vue实例了。
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:03:16  更:2022-03-03 16:07:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:19:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码