没有合适的资源?快使用搜索试试~ 我知道了~
详解vue为什么要求组件模板只能有一个根元素
1 下载量 73 浏览量
2020-10-16
16:36:35
上传
评论
收藏 57KB PDF 举报
温馨提示
试读
2页
主要介绍了vue为什么要求组件模板只能有一个根元素,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
资源推荐
资源详情
资源评论
详解详解vue为什么要求组件模板只能有一个根元素为什么要求组件模板只能有一个根元素
主要介绍了vue为什么要求组件模板只能有一个根元素,小编觉得挺不错的,现在分享给大家,也给大家做个参
考。一起跟随小编过来看看吧
我是在知乎上看到的这个问题,转念一想,用了大半年的vue,好像真的没有了解过:
‘为什么只能有且只有一个根元素'
于是我花了二十多分钟去找了一下答案......竟然没有找到答案....
好的现在我来说说我的理解,如果有不对的地方欢迎指出。
我觉得这个问题需要从两个方面来说起:我觉得这个问题需要从两个方面来说起:
1.new Vue({el:'#app'})
2.单文件组件中,template下的元素div
一、当我们实例化Vue的时候,填写一个el选项,来指定我们的SPA入口:
let vm = new Vue({
el:'#app'
})
同时我们也会在body里面新增一个id为app的div
<body>
<div id='app'></div>
</body>
这很好理解,就是为vue开启一个入口,那我们不妨来想想,如果我在body下这样
<body>
<div id='app1'></div>
<div id='app2'></div>
</body>
Vue其实并不知道哪一个才是我们的入口,因为对于一个入口来讲,这个入口就是一个‘Vue类',Vue需要把这个入口里面的所
有东西拿来渲染,处理,最后再重新插入到dom中。
如果同时设置了多个入口,那么vue就不知道哪一个才是这个‘类'。
二、当我们在webpack搭建的vue开发环境下,使用单文件组件时,你可能会这样:
<template>
<div class='component'></div>
</template>
那这里为什么那这里为什么template下也必须有且只能有一个下也必须有且只能有一个div呢?呢?
这里我们要先看一看template这个标签,这个标签是HTML5出来的新标签,它有三个特性:
1.隐藏性:该标签不会显示在页面的任何地方,即便里面有多少内容,它永远都是隐藏的状态;
2.任意性:该标签可以写在页面的任何地方,甚至是head、body、sciprt标签内;
3.无效性:该标签里的任何HTML内容都是无效的,不会起任何作用;
但是呢,你可以通过但是呢,你可以通过innerHTML来获取到里面的内容。来获取到里面的内容。
知道了这个,我们再来看.vue的单文件组件。其实本质上,一个单文件组件,本质上(我认为)会被各种各样的loader处理成
为.js文件(因为当你import一个单文件组件并打印出来的时候,是一个vue实例),通过template的任意性我们知道,template
包裹的HTML可以写在任何地方,那么对于一个.vue来讲,这个template里面的内容就是会被vue处理为虚拟dom并渲染的内
容,导致结果又回到了开始 :既然一个.vue单文件组件是一个vue实例,那么这个实例的入口在哪里?
资源评论
weixin_38500047
- 粉丝: 9
- 资源: 979
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Yolov8改进---注意力机制:Polarized Self-Attention,效果秒杀CBAM、SE.html
- 人才网站设计-asp.net+sql-(系统源码)
- asp.net+sql人才网站设计-含系统源码
- C#应用的用户配置窗体方案
- python实现绘制爱心图形的代码
- JAVAWEB项目-校园订餐系统项目源码.zip
- flink-1.19.0-bin-scala-2.12.tgz flink-1.16.3-bin-scala-2.12.tgz
- javaWeb项目-物资管理系统项目源码.zip
- javaweb项目-物流配货项目源码.zip
- 使用C++基于颜色纹理特征的人脸活体检测实现-附项目源码.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功