02. react-虚拟DOM的两种创建方式

react-虚拟DOM的两种创建方式

一、虚拟DOM与真实DOM

在这里插入图片描述
在这里插入图片描述

关于虚拟DOM:

1.本质是Object类型的对象(一般对象)
2.虚拟DOM比较“轻”,真实DOM比较“重”。
因为虚拟DOM是React内部在用,无需真实DOM上那么多的属性。
3.虚拟DOM最终会被React转化为真实DOM,呈现在页面上。
<script type="text/babel"> /* 此处一定要写babel */
		//1.创建虚拟DOM
		const VDOM = (  /* 此处一定不要写引号,因为不是字符串 */
			<h1 id="title">
				<span>Hello,React</span>
			</h1>
		)
		//2.渲染虚拟DOM到页面
		ReactDOM.render(VDOM,document.getElementById('test'))
		const TDOM = document.getElementById('demo')
		console.log('虚拟DOM',VDOM); // 方法比较少
		console.log('真实DOM',TDOM); // 对象属性比较多
		// console.log(typeof VDOM);
		// console.log(VDOM instanceof Object);
		/* 
		关于虚拟DOM:
			1.本质是Object类型的对象(一般对象)
			2.虚拟DOM比较“轻”,真实DOM比较“重”,因为虚拟DOM是React内部在用,无需真实DOM上那么多的属性。
			3.虚拟DOM最终会被React转化为真实DOM,呈现在页面上。
		 */
	</script>

二、JSX语法

	使用jsx语法,让编码更加流畅
	jsx是原始js的语法糖,更加便捷
<script type="text/babel" > /* 此处一定要写babel */
		//1.创建虚拟DOM
		// 使用jsx语法,让编码更加流畅
		// jsx是原始js的语法糖,更加便捷
		const VDOM = (  /* 此处一定不要写引号,因为不是字符串 */
			<h1 id="title">
				<span>Hello,React</span>
			</h1>
		)
		//2.渲染虚拟DOM到页面
		ReactDOM.render(VDOM,document.getElementById('test'))
	</script>

三、JS创建虚拟DOM

原生js 创建虚拟DOM会层层嵌套,较为繁琐
代码如下:

<script type="text/javascript">
		//1.创建虚拟DOM
		// 使用原始Js  使用原始React.createElement创建js
		// const Vdom = React.createElement(标签名,标签属性,内容)
		// 原生js 创建虚拟DOM会层层嵌套
		// 翻译的结果
		const VDOM = React.createElement('h1', {
			id: 'test'
		}, React.createElement('span', {}, '我的世界'))
		//2.渲染虚拟DOM到页面
		ReactDOM.render(VDOM, document.getElementById('test'))
	</script>

总结

  • 本质上JSX创建的虚拟DOM最终会由babel转换为JS创建虚拟DOM
  • JSX语法简洁,JS构造多层的虚拟DOM会层层嵌套,导致代码冗余
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值