当前位置: 首页 > news >正文

vue2入门--->非单文件组件(html直接使用组件)

1.非单文件组件

1.1 介绍

1.使用步骤
<!-- 
   Vue中使用组件的三大步骤:
         一、定义组件(创建组件)
         二、注册组件
         三、使用组件(写组件标签)

   一、如何定义一个组件?
            使用Vue.extend(options)创建,其中options和new Vue(options)时传入的那个options几乎一样,但也有点区别;
            区别如下:
                  1.el不要写,为什么? ——— 最终所有的组件都要经过一个vm的管理,由vm中的el决定服务哪个容器。
                  2.data必须写成函数,为什么? ———— 避免组件被复用时,数据存在引用关系。
            备注:使用template可以配置组件结构。

   二、如何注册组件?
               1.局部注册:靠new Vue的时候传入components选项
               2.全局注册:靠Vue.component('组件名',组件)

   三、编写组件标签:
               <school></school>
-->

2. 几个注意点

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

         2.关于组件标签:
                  第一种写法:<school></school>
                  第二种写法:<school/>
                  备注:不用使用脚手架时,<school/>会导致后续组件不能渲染。

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

1.2 组件创建(定义)

1.2.1 创建介绍

1. 通过Vue.extend({})进行创建定义,可以省略为{}

2.里面的内容几乎与vue示例里面的一样,正常写即可

3.列子

const student = Vue.extend({
   template:`
      <div>
         <h2>学生姓名:{{studentName}}</h2>
         <h2>学生年龄:{{age}}</h2>
      </div>
   `,
   data(){
      return {
         studentName:'张三',
         age:18
      }
   }
})

4.简写例子

 {
   template:`
      <div>
         <h2>学生姓名:{{studentName}}</h2>
         <h2>学生年龄:{{age}}</h2>
      </div>
   `,
   data(){
      return {
         studentName:'张三',
         age:18
      }
   }
}

5. export default

暴露,导入的时候 from xx import xxx

不暴露的话,无法导入

1.2.2 代码示例

//第一步:创建school组件
		const school = Vue.extend({
			template:`
				<div class="demo">
					<h2>学校名称:{{schoolName}}</h2>
					<h2>学校地址:{{address}}</h2>
					<button @click="showName">点我提示学校名</button>	
				</div>
			`,
			// el:'#root', //组件定义时,一定不要写el配置项,因为最终所有的组件都要被一个vm管理,由vm决定服务于哪个容器。
			data(){
				return {
					schoolName:'尚硅谷',
					address:'北京昌平'
				}
			},
			methods: {
				showName(){
					alert(this.schoolName)
				}
			},
		})

		//第一步:创建student组件
		const student = Vue.extend({
			template:`
				<div>
					<h2>学生姓名:{{studentName}}</h2>
					<h2>学生年龄:{{age}}</h2>
				</div>
			`,
			data(){
				return {
					studentName:'张三',
					age:18
				}
			}
		})
		
		//第一步:创建hello组件
		const hello = Vue.extend({
			template:`
				<div>	
					<h2>你好啊!{{name}}</h2>
				</div>
			`,
			data(){
				return {
					name:'Tom'
				}
			}
		})

1.3 注册

1.3.1 介绍

1.示例
Vue.component('hello',hello)

//创建vm
new Vue({
   el:'#root',
   data:{
      msg:'你好啊!'
   },
   //第二步:注册组件(局部注册)
   components:{
      school,
      student
   }
})

2.组件的名称由components的key决定,如果key value一致,可以省略,写个key即可

1.3.2 代码示例

//第二步:全局注册组件
		Vue.component('hello',hello)

		//创建vm
		new Vue({
			el:'#root',
			data:{
				msg:'你好啊!'
			},
			//第二步:注册组件(局部注册)
			components:{
				school,
				student
			}
		})

1.4 使用

<div id="root">
			<!-- 第三步:编写组件标签 -->
			<student></student>
		</div>

1.5. 完整实例

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>基本使用</title>
		<script type="text/javascript" src="../js/vue.js"></script>
	</head>
	<body>

		<!-- 准备好一个容器-->
		<div id="root">
			<hello></hello>
			<hr>
			<h1>{{msg}}</h1>
			<hr>
			<!-- 第三步:编写组件标签 -->
			<school></school>
			<hr>
			<!-- 第三步:编写组件标签 -->
			<student></student>
		</div>

		<div id="root2">
			<hello></hello>
		</div>
	</body>

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

		//第一步:创建school组件
		const school = Vue.extend({
			template:`
				<div class="demo">
					<h2>学校名称:{{schoolName}}</h2>
					<h2>学校地址:{{address}}</h2>
					<button @click="showName">点我提示学校名</button>	
				</div>
			`,
			// el:'#root', //组件定义时,一定不要写el配置项,因为最终所有的组件都要被一个vm管理,由vm决定服务于哪个容器。
			data(){
				return {
					schoolName:'尚硅谷',
					address:'北京昌平'
				}
			},
			methods: {
				showName(){
					alert(this.schoolName)
				}
			},
		})

		//第一步:创建student组件
		const student = Vue.extend({
			template:`
				<div>
					<h2>学生姓名:{{studentName}}</h2>
					<h2>学生年龄:{{age}}</h2>
				</div>
			`,
			data(){
				return {
					studentName:'张三',
					age:18
				}
			}
		})
		
		//第一步:创建hello组件
		const hello = Vue.extend({
			template:`
				<div>	
					<h2>你好啊!{{name}}</h2>
				</div>
			`,
			data(){
				return {
					name:'Tom'
				}
			}
		})
		
		//第二步:全局注册组件
		Vue.component('hello',hello)

		//创建vm
		new Vue({
			el:'#root',
			data:{
				msg:'你好啊!'
			},
			//第二步:注册组件(局部注册)
			components:{
				school,
				student
			}
		})

		new Vue({
			el:'#root2',
		})
	</script>
</html>

2. 组件的嵌套

2.1 代码示例

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>组件的嵌套</title>
		<!-- 引入Vue -->
		<script type="text/javascript" src="../js/vue.js"></script>
	</head>
	<body>
		<!-- 准备好一个容器-->
		<div id="root">
			
		</div>
	</body>

	<script type="text/javascript">
		Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示。

		//定义student组件
		const student = Vue.extend({
			name:'student',
			template:`
				<div>
					<h2>学生姓名:{{name}}</h2>	
					<h2>学生年龄:{{age}}</h2>	
				</div>
			`,
			data(){
				return {
					name:'尚硅谷',
					age:18
				}
			}
		})
		
		//定义school组件
		const school = Vue.extend({
			name:'school',
			template:`
				<div>
					<h2>学校名称:{{name}}</h2>	
					<h2>学校地址:{{address}}</h2>	
					<student></student>
				</div>
			`,
			data(){
				return {
					name:'尚硅谷',
					address:'北京'
				}
			},
			//注册组件(局部)
			components:{
				student
			}
		})

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

		//创建vm
		new Vue({
			template:'<app></app>',
			el:'#root',
			//注册组件(局部)
			components:{app}
		})
	</script>
</html>

3. 关于VueComponent

3.1 介绍

<!-- 
   关于VueComponent:
            1.school组件本质是一个名为VueComponent的构造函数,且不是程序员定义的,是Vue.extend生成的。

            2.我们只需要写<school/>或<school></school>,Vue解析时会帮我们创建school组件的实例对象,
               即Vue帮我们执行的:new VueComponent(options)。

            3.特别注意:每次调用Vue.extend,返回的都是一个全新的VueComponent!!!!

            4.关于this指向:
                  (1).组件配置中:
                           data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【VueComponent实例对象】。
                  (2).new Vue(options)配置中:
                           data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【Vue实例对象】。

            5.VueComponent的实例对象,以后简称vc(也可称之为:组件实例对象)。
               Vue的实例对象,以后简称vm。
-->

3.2 代码示例

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>VueComponent</title>
		<script type="text/javascript" src="../js/vue.js"></script>
	</head>
	<body>

		<!-- 准备好一个容器-->
		<div id="root">
			<school></school>
			<hello></hello>
		</div>
	</body>

	<script type="text/javascript">
		Vue.config.productionTip = false
		
		//定义school组件
		const school = Vue.extend({
			name:'school',
			template:`
				<div>
					<h2>学校名称:{{name}}</h2>	
					<h2>学校地址:{{address}}</h2>	
					<button @click="showName">点我提示学校名</button>
				</div>
			`,
			data(){
				return {
					name:'尚硅谷',
					address:'北京'
				}
			},
			methods: {
				showName(){
					console.log('showName',this)
				}
			},
		})

		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)

		//创建vm
		const vm = new Vue({
			el:'#root',
			components:{school,hello}
		})
	</script>
</html>

 

相关文章:

  • 【CSS】伪元素和伪类选择器区别
  • C++ 正则表达式(匹配、搜索、替换)
  • 2.C#:lenson2_TextBox
  • 神经网络编程的34个案例,神经网络编程是什么
  • 链接生成-链接生成器-免费批量在线链接生成器
  • springboot+vue3+elementui plus汽车租赁网站源码
  • java中类中代码的执行顺序,附简繁两个Demo
  • 数据中心设计方案 实例,数据中心网络设计方案
  • 算法笔记(四)从暴力递归到动态规划
  • golang设计模式——行为模式
  • springboot版HelloWorld
  • 在portacle中获取EMACS Lisp帮助文档的方法(Win11)
  • 线性代数学习笔记8-1:复数矩阵与Hermite矩阵、酉矩阵、傅里叶矩阵和快速傅里叶变换FFT
  • java ssm创意设计分享系统
  • ABAP Debug 调试功能
  • [笔记] php常见简单功能及函数
  • 3.7、@ResponseBody 和 @RestController
  • Android框架之Volley
  • C++回声服务器_9-epoll边缘触发模式版本服务器
  • docker-consul
  • iOS帅气加载动画、通知视图、红包助手、引导页、导航栏、朋友圈、小游戏等效果源码...
  • JavaScript设计模式系列一:工厂模式
  • JWT究竟是什么呢?
  • RxJS: 简单入门
  • SegmentFault 2015 Top Rank
  • web标准化(下)
  • 搭建gitbook 和 访问权限认证
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 推荐一个React的管理后台框架
  • 文本多行溢出显示...之最后一行不到行尾的解决
  • 我是如何设计 Upload 上传组件的
  • 写代码的正确姿势
  • 智能网联汽车信息安全
  • 中文输入法与React文本输入框的问题与解决方案
  • #define与typedef区别
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (9)YOLO-Pose:使用对象关键点相似性损失增强多人姿态估计的增强版YOLO
  • (C#)if (this == null)?你在逗我,this 怎么可能为 null!用 IL 编译和反编译看穿一切
  • (Redis使用系列) Springboot 使用redis的List数据结构实现简单的排队功能场景 九
  • (zhuan) 一些RL的文献(及笔记)
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (二)fiber的基本认识
  • (附源码)ssm教师工作量核算统计系统 毕业设计 162307
  • (附源码)计算机毕业设计ssm电影分享网站
  • (论文阅读11/100)Fast R-CNN
  • (十一)JAVA springboot ssm b2b2c多用户商城系统源码:服务网关Zuul高级篇
  • (一)【Jmeter】JDK及Jmeter的安装部署及简单配置
  • (一)WLAN定义和基本架构转
  • (转)AS3正则:元子符,元序列,标志,数量表达符
  • (转)IIS6 ASP 0251超过响应缓冲区限制错误的解决方法
  • *setTimeout实现text输入在用户停顿时才调用事件!*
  • . NET自动找可写目录
  • .java 9 找不到符号_java找不到符号
  • .mysql secret在哪_MySQL如何使用索引
  • .NET CF命令行调试器MDbg入门(一)