学习day51

news2025/1/11 11:35:49

几个注意点:

          1.关于组件名:

            一个单词组成:

              第一种写法(首字母小写):school

              第二种写法(首字母大写):School

            多个单词组陈:

              第一种写法(kebab-case命名):my-school

              第二种写法(CamelCase命名):MySchool(需要Vue脚手架)

            备注:

              (1)组件名尽可能回避HTML中已有的元素名称,例如:h2,H2都不行

              (2)可以使用name配置项指定组件再开发者工具中呈现的名字

          2.关于组件标签

              第一种写法:<school></school>

              第二种写法:<school/>

          3.一个简写方式:

              const school =Vue.extend(options) 可简写为: const school=options

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>几个注意点</title>
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>

    <!-- 
        几个注意点:
          1.关于组件名:
            一个单词组成:
              第一种写法(首字母小写):school
              第二种写法(首字母大写):School
            多个单词组陈:
              第一种写法(kebab-case命名):my-school
              第二种写法(CamelCase命名):MySchool(需要Vue脚手架)
            备注:
              (1)组件名尽可能回避HTML中已有的元素名称,例如:h2,H2都不行
              (2)可以使用name配置项指定组件再开发者工具中呈现的名字

          2.关于组件标签
              第一种写法:<school></school>
              第二种写法:<school/>

          3.一个简写方式:
              const school =Vue.extend(options) 可简写为: const school=options

     -->
    <div id="root">
        <h2>{{msg}}</h2>
        <school></school>
    </div>
    
</body>
<script type="text/javascript">
    Vue.config.productionTip=false

    //定义组件
    const school=Vue.extend({
        template:`
        <div>
            <h2>学校名称{{name}}</h2>
            <h2>学校地址{{adress}}</h2>
            </div>
        `,
        data(){
            return{
                name:'尚硅谷',
                adress:'北京昌平'
            }
           
        }
    })

    //组件注册
    //Vue.component
    
    new Vue({
        el:"#root",
        data:{
           msg:'欢迎学习vue'
        },
        //局部注册
        components:{
            school:school
        }

    })
</script>

</html>

组件的嵌套

实现如下嵌套

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>组件的嵌套</title>
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        

    </div>

    
    
</body>
<script type="text/javascript">
    Vue.config.productionTip=false

    //定义student组件
    const student=Vue.extend({
        name:'student',
        template:`
        <div>
        <h2>学生姓名:{{name}}</h2>
        <h2>学生年龄:{{age}}</h2>
        </div>
        `,
        data(){
           return{
                name:'tom',
                age:18
           }
        }
    })

    //定义组件
    const school=Vue.extend({
        name:'school',
        template:`
        <div>
            <h2>学校名称{{name}}</h2>
            <h2>学校地址{{adress}}</h2>
            <student></student>
            </div>
        `,
        data(){
            return{
                name:'尚硅谷',
                adress:'北京昌平'
            }
        },
        //注册组件
        components:{
            student
        }
    })

    const hello=Vue.extend({
        template:`
        <div>
            <h2>欢迎来到{{msg}}学习</h2>
            </div>
        `,
        data(){
            return{
                msg:'尚硅谷'
            }
        }
    })
    
    //定义app组件
    const app =Vue.extend({
        template:`
        <div>
            <school></school>
            <hello></hello>
            </div>
        `,
        components:{
            school,
            hello
        }

    })
    
    new Vue({
        template:`
        <app></app>
        `,
        el:"#root",
        //局部注册
        components:{
            app
        }

    })
</script>

</html>

关于VueComponent

在这里插入图片描述

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>几个注意点</title>
    <script type="text/javascript" src="../js/vue.js"></script>
</head>
<body>

    <div id="root">
        <hello></hello>
        <school></school>

    </div>
    
</body>
<script type="text/javascript">
    Vue.config.productionTip=false

    //定义组件
    const school=Vue.extend({
        name:'school',
        template:`
        <div>
            <h2>学校名称{{name}}</h2>
            <h2>学校地址{{adress}}</h2>
            </div>
        `,
        data(){
            return{
                name:'尚硅谷',
                adress:'北京昌平'
            }
           
        }
    })

    const test=Vue.extend({
        template:`<span>atguigu</span>`,
    })
    
    //定义hello组件
    const hello =Vue.extend({
        template:`
        <div>
        <h2>{{msg}}</h2>
        <test></test>
        </div>
        `,
        data(){
            return{
                msg:'你好啊'
            }
        },
        components:{
            test
        }
    })

    console.log('@',school)
    console.log('#',hello)
    
    new Vue({
        el:"#root",
        
        //局部注册
        components:{
            school:school,
            hello
        }

    })
</script>

</html>

一个内置关系

VueComponent.protype._proto_=Vue.protype

Vue 和 vm的关系
Vue是一个函数,vm是其new出来的实例对象

因此:vm.__proto__ === Vue.prototype

VueComponent 和 VueComponent实例对象的关系
VueComponent 是一个函数,VueComponent实例对象是一个对象

当渲染VueComponent时,VueComponent实例对象就被自动new出来了

因此:VueComponent实例对象.___proto___=== VueComponent.prototype.__proto__

有了上面的铺垫,Vue有一个重要的内置关系:
VueComponent.prototype.__proto__ === Vue.prototype
所以:VueComponent实例对象.__proto__ === VueComponent.prototype.__proto__ === vm.__proto__ === Vue.prototype
有这个内置关系的原因是: 让VueComponent实例对象可以访问到Vue原型的属性和方法。

image.png

 

单文件组件

由下到上

School.vue

<template>
<!-- 组件的结构 -->
<div class="demo">
    <h2>学校名称:{{schoolName}}</h2>
    <h2>学校地址:{{adress}}</h2>
    <button @click="showName"> 点我提示学校名</button>
</div>
</template>


<script>
//组件交互相关的代码
export default{
    name:'School',
     data(){
        return{
            schoolName:'尚硅谷',
            adress:'北京昌平'
        }
    },
    methods: {
        showName(){
            alert(this.schoolName)
        }
    },
}

</script>

<style>
/** 组件的样式 */
.demo{
    background-color: orange;
}
</style>

Student.vue

<template>
<div >
    <h2>学生姓名:{{name}}</h2>
    <h2>学生年龄:{{age}}</h2>
</div>  
</template>

<script>

export default{
    name:'Student',
    data(){
        return{
            name:'tom',
            age:19
        }
    }
}
</script>

App.vue

<template>
<div>
    <School></School>
    <Student></Student>
</div>
    
</template>

<script>
  //引入组件
  import School from './School.vue'
  import Student from './Student.vue'

  export default{
    name:'App',
    components:{
    School,
    Student
}
  }

</script>

main.js

import App from './App'

new Vue({
    el:"#root",
    template:`<App></App>`,
    components:{App}
})

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>练习单文件组件的语法</title>
</head>
<body>
    <div id="root">
        
    </div>
    <script type="text/javascript" src="../js/vue.js"></script>
    <script type="text/javascript" src="./main.js"></script>
    
</body>
</html>

但是仅仅只是这样设置的话,仍然时不可执行的,因为缺少脚手架。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/778579.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基础算法(三)

目录 一、双指针算法 二、位运算 三、区间合并 一、双指针算法 双指针算法模板: for(int i 0,j 0;i < n;i) {while(j < i && check(i,j)) j;//每道题的具体逻辑 } 1.1两个指针指向两个队列1.2两个指针指向一个队列 案例习题: 分割字符串 #include<…

【C语言】自定义类型:结构体,枚举,联合

目录 前言&#xff1a;一.结构体1.结构体的声明2.结构体特殊的声明3.结构体的自引用4.结构体变量的定义和初始化5.结构体内存对齐6.修改默认对齐数7.结构体传参 二.位段1.什么是位段2.位段的内存分配 三.枚举1.枚举的定义2.枚举的优点 四.联合&#xff08;共用体&#xff09;1.…

php使用PDO_sqlsrv

php拓展下载&#xff1a;Microsoft Drivers for PHP 发行说明 - PHP drivers for SQL Server | Microsoft Learn 参考文章&#xff1a;php7.3.4 pdo方式连接sqlserver 设置方法_pdo sqlserver_黑贝是条狗的博客-CSDN博客 php5.6.9安装sqlsrv扩展&#xff08;windows&#xff0…

BEVDet 论文解读

BEVDet: High-Performance Multi-Camera 3D Object Detection in Bird-Eye-View 作者单位 PhiGent Robotics 目的 2D 的视觉感知在过去的几年里有了急速的发展&#xff0c;涌现出一些优秀的范式工作&#xff0c;这些工作有较高的性能&#xff0c;可扩展性&#xff0c;以及多…

【前端设计】使用Verdi查看波形时鼠标遮住了parameter值怎么整

盆友&#xff0c;你们在使用Verdi的时候&#xff0c;有没有遇到过鼠标遮挡着了parameter数值的场景&#xff1f;就跟下面这个示意图一样&#xff1a; 最可恨的是这个参数值他会跟着你的鼠标走&#xff0c;你想把鼠标移开看看看这个例化值到底是多大吧&#xff0c;这个数他跟着你…

云原生基础设施实践:NebulaGraph 的 KubeBlocks 集成故事

像是 NebulaGraph 这类基础设施上云&#xff0c;通用的方法一般是将线下物理机替换成云端的虚拟资源&#xff0c;依托各大云服务厂商实现“服务上云”。但还有一种选择&#xff0c;就是依托云数据基础设施&#xff0c;将数据库产品变成为云生态的一环&#xff0c;不只是提供自身…

直播回顾 | SDS 容灾方案,让制品数据更安全

7 月 18 日&#xff0c;腾讯云 CODING 与 XSKY星辰天合联合举办了主题为“SDS 容灾方案&#xff0c;让制品数据更安全”的线上研讨会。 来自腾讯云 CODING 的高级解决方案架构师陈钧桐和 XSKY星辰天合金融行业解决方案专家战策&#xff0c;分享了制品管理的困境与需求、腾讯云…

【数据挖掘】如何修复时序分析缺少的日期

一、说明 我撰写本文的目的是通过引导您完成一个示例来帮助您了解 TVF 以及如何使用它们&#xff0c;该示例解决了时间序列分析中常见的缺失日期问题。 我们将介绍&#xff1a; 如何生成日期以填补数据中缺失的空白如何创建 TVF 和参数的使用如何呼叫 TVF我们将考虑扩展我们的日…

Less知识点整理学习笔记

文章目录 1. Less介绍2. 安装2.1 部署node.js环境2.2 安装Less2.3 WebStorm配置Less 3. Less语法3.1 变量3.2 嵌套3.3 运算 1. Less介绍 Less是CSS预处理语言&#xff0c;可以使用变量、嵌套、运算等&#xff0c;便于维护项目CSS样式代码。 2. 安装 2.1 部署node.js环境 官…

Python爬虫学习笔记(十二)————scrapy案例

目录 1.yield 2.案例&#xff1a;当当网 3.案例&#xff1a;电影天堂 1.yield &#xff08;1&#xff09;带有 yield 的函数不再是一个普通函数&#xff0c;而是一个生成器generator&#xff0c;可用于迭代 &#xff08;2&#xff09; yield 是一个类似 return 的关键字&am…

《数据分析-JiMuReport07》JiMuReport报表开发-下拉框条数参数调整

JimuReport报表下拉框条数参数调整 {selectSearchPageSize:n} 1.下拉框条数限制 下拉框默认只显示10条记录&#xff0c;如果想要显示更多条数可以通过添加参数实现。 2.参数 selectSearchPageSize参数&#xff0c;设置参数大小 3.效果 可以看到设置的下拉框条数20条已经实现

细说小程序底部标签---【浅入深出系列006】

浅入深出系列总目录在000集 如何0元学微信小程序–【浅入深出系列000】 文章目录 本系列校训学习资源的选择 学习语法的前提底部标签的总概鹅厂的自定义标签官方说明&#xff1a; 先来了解app.json文件tabBar 位于app.json哪里 使用流程要注意的是&#xff1a;配套资源作业&a…

el-popover在原生table中,弹出多个以及内部取消按钮无效问题

问题&#xff1a;当el-popover和原生table同时使用的时候会失效&#xff08;不是el-table) <el-popover placement"bottom" width"500" trigger"click" :key"popover-${item.id}"></el-popover> 解决&#xff1a; :key…

虚拟数字人——NeRF实现实时对话数字人

前言 1.这是一个能实时对话的虚拟数字人demo,使用的是NeRF&#xff08;Neural Radiance Fields&#xff09;&#xff0c;训练方式可以看看我前面的博客。 2.文本转语音是用了VITS语音合成&#xff0c;项目git:https://github.com/jaywalnut310/vits . 3.语言模型是用了新开…

Jenkins从配置到实战(一) - 实现C/C++项目自动化编译

前言 本文章主要介绍了&#xff0c;如何去安装和部署Jenkins&#xff0c;并实现自动拉取项目代码&#xff0c;自动化编译流程。 网站 官网中文网站 下载安装 可以下载这个 安装jenkins前先安装java yum search java|grep jdkyum install java-1.8.0-openjdk 安装jenkins j…

NE555 PWM输出

NE555是一种集成电路&#xff08;IC&#xff09;&#xff0c;通常用于电子电路的各种目的&#xff0c;包括计时器、振荡器等等。 本文介绍搭建NE555电路输出PWM信号&#xff0c;电路如图下&#xff1a; 使用该电路可以输出PWM占空比≥50%波形&#xff0c;仿真波形如下图&#…

20230723在win10的命令行下显示文本文件的内容type

20230723在win10的命令行下显示文本文件的内容type 2023/7/23 20:35 百度搜索&#xff1a;WINDOWS 命令行 打开文本文件 windows命令行读取文件命令-WinFrom控件库|.net开源控件库... 2023年7月14日 linux下,可能会用到cat或都是more命令,windows下可以使用type或more命令 type…

VMware Fusion 14 Tech Preview - 适用于 Arm 的 Windows 11 上的全面 3D 加速

VMware Fusion 14 Tech Preview - 适用于 Arm 的 Windows 11 上的全面 3D 加速 VMware Fusion Tech Preview 2023 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-fusion-14/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;…

求解包含约束的最优化问题:罚函数法

文章目录 外点罚函数法内点罚函数法罚函数法 vs 拉格朗日乘子法 外点罚函数法 针对包含约束条件的最优化问题&#xff0c;此前介绍的拉格朗日乘子法和KKT条件已经提供一种有效的解决方案。但由于我是从智能优化算法入门运筹优化行业的&#xff0c;所以在遇到这类问题时&#x…

day35-Image Carousel(图片轮播图简易版)

50 天学习 50 个项目 - HTMLCSS and JavaScript day35-Image Carousel&#xff08;图片轮播图简易版&#xff09; 效果 index.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport…